【备忘】EntityFramework 6 升级到 EntityFrameworkCore 注意点

正在将一个 .net framework 4.5 的项目升级到 .net core 2.1,其中使用到了 EF6,经历了一些修改:

  1. 命名空间的变化基本上可以靠自动提示补充完整,不需要强记。
  2. DbQuery<T> 返回结果改为:IQueryable<T>
  3. Include 方法已经支持传入类型,可以不再需要扩展。
  4. DbContext.Configuration.AutoDetectChangesEnabled属性移动到:DbContext.ChangeTracker.AutoDetectChangesEnabled
  5. 自定义的继承自 DbContext 的类中,连接字符串可以使用 OnConfiguring 重写方法进行定义,如:
public partial class SenparcEntities : DbContext
    {
        /// <summary>
        /// 连接字符串
        /// </summary>
        internal string ConnectionString { get; set; }


        public DbSet<Account> Accounts { get; set; }
        public DbSet<SystemConfig> SystemConfigs { get; set; }

        public SenparcEntities(string connectionString)
        {
            ConnectionString = connectionString;
        }

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            //配置连接字符串
            optionsBuilder.UseSqlServer(ConnectionString);

            base.OnConfiguring(optionsBuilder);
        }
    }

或者在 Startup.cs 中使用 .net core 的 DI 方式注入:

services.AddDbContext<DataContext>(options => options.UseSqlite(connection));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值