正在将一个 .net framework 4.5 的项目升级到 .net core 2.1,其中使用到了 EF6,经历了一些修改:
- 命名空间的变化基本上可以靠自动提示补充完整,不需要强记。
DbQuery<T>返回结果改为:IQueryable<T>。Include方法已经支持传入类型,可以不再需要扩展。DbContext.Configuration.AutoDetectChangesEnabled属性移动到:DbContext.ChangeTracker.AutoDetectChangesEnabled。- 自定义的继承自
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));
这篇博客介绍了将基于.NET Framework 4.5的项目迁移到.NET Core 2.1的过程中,如何处理Entity Framework 6(EF6)的变更。主要变化包括命名空间的自动补全、DbQuery<T>替换为IQueryable<T>、Include方法的改进、DbContext.Configuration属性的移动以及使用OnConfiguring方法设置连接字符串。此外,还展示了在Startup.cs中通过依赖注入配置DbContext的例子。
1480

被折叠的 条评论
为什么被折叠?



