基于EF Core的Code First模式的DotNetCore快速开发框架
Nuget [最新版本:2.2.0]
- Install-Package Zxw.Framework.NetCore -Version 2.2.0
- dotnet add package Zxw.Framework.NetCore --version 2.2.0
开发环境
- VS2017 / VS Code
- .net core 2.2
支持的数据库
- SQL Server
- MySQL
- Sqlite
- InMemory
- PostgreSQL
- Oracle (第三方驱动Citms.EntityFrameworkCore.Oracle)
- MongoDB (Beta)(第三方驱动Blueshift.EntityFrameworkCore.MongoDB)
日志组件
- log4net
DI组件
- Autofac
- Aspectcore.Injector
缓存组件使用
本项目采用的AOP中间件 :AspectCore-Framework
- MemoryCacheAttribute :基于MemoryCache的缓存拦截组件
- RedisCacheAttribute :基于Redis的缓存拦截组件
如何使用:
public interface ITutorClassTypeRepository:IRepository<TutorClassType, Int32>
{
[MemoryCache]//使用MemoryCache,缓存有效时间默认10分钟
IList<TutorClassType> GetByMemoryCached(Expression<Func<TutorClassType, bool>> where = null);
[RedisCache(Expiration = 5)]//使用Redis,缓存有效时间为5分钟
IList<TutorClassType> GetByRedisCached(Expression<Func<TutorClassType, bool>> where = null);
}
2019/04/25
- 1.修改缓存拦截器默认key格式为:{namespace}{class}{method}{参数值hashcode}
- 2.缓存拦截器添加对Task<>类型的支持
2019/04/18
- 1.删除触发器功能...
- 2.实现多数据库上下文。用法:
//注入数据库上下文
services.AddDbContextFactory(factory =>
{
factory.AddDbContext<PostgreSQLDbContext>("db1", new DbContextOption(){ConnectionString = "User ID=postgres;Password=123456;Host=localhost;Port=5432;Database=ZxwPgDemo;Pooling=true;" });
factory.AddDbContext<SqlServerDbContext>("db2", new DbContextOption() { ConnectionString = "" });
factory.AddDbContext<MongoDbContext>("db3", new DbContextOption() { ConnectionString = "" });
});
//获取
public class TestController
{
public IDbContextCore DbContext1 { get; set; }
public IDbContextCore DbContext2 { get; set; }
public IDbContextCore DbContext3 { get; set; }
public TestController(DbContextFactory factory)
{
DbContext1 = factory.GetDbContext("db1");
DbContext2 = factory.GetDbContext("db2");
DbContext3 = factory.GetDbContext("db3");
}
public void Run()
{
var db = DbContext1.GetDatabase();
Console.WriteLine();
}
}
- 3.多数据库上下文支持属性注入,用法如下:(具体请参考单元测试)
public class TestRepository: BaseRepository<MongoModel, ObjectId>, IMongoRepository
{
[FromDbContextFactory("db1")]
public IDbContextCore DbContext1 { get; set; }
[FromDbContextFactory("db2")]
public IDbContextCore DbContext2 { get; set; }
[FromDbContextFactory("db3")]
public IDbContextCore DbContext3 { get; set; }
public void Run()
{
Console.WriteLine("Over!");
}
public TestRepository(IDbContextCore dbContext) : base(dbContext)
{
}
}
2018/09/24
- 1.实现Oracle for EfCore,引用第三方驱动Citms.EntityFrameworkCore.Oracle
- 2.实现MongoDB for EfCore,引用第三方驱动Blueshift.EntityFrameworkCore.MongoDB
2018/08/26
- 1.添加自定义视图分页查询,数据库分页,目前只支持sqlserver
- 2.update packages
2018/07/06 合并dev分支到master
- 1.添加EFCore直接返回DataTable功能
- 2.DBFirst功能,目前仅支持SQL Server、MySQL、NpgSQL三种数据库。根据已存在的数据表直接生成实体代码,详见CodeGenerator
- 3.添加单元测试项目,并完成对以上两点新功能的测试
- 4.引入IOC容器Aspectcore.Injector,详见AspectCoreContainer.cs
- 本开源项目遵守MIT开源协议,请保留原作者出处。