【发布时间】:2019-05-20 19:23:54
【问题描述】:
我正在使用 SQLite 和 EntityFramework。
当我尝试运行命令enable-migrations 时,我收到此错误。
找不到提供程序“System.Data.SQLite”的 MigrationSqlGenerator。使用目标迁移配置类中的 >SetSqlGenerator 方法 >注册其他 SQL 生成器
这是我的 DBContext 和我的 DBConfiguration
public class SQLiteConfiguration : DbConfiguration
{
public SQLiteConfiguration()
{
SetProviderFactory("System.Data.SQLite", SQLiteFactory.Instance);
SetProviderFactory("System.Data.SQLite.EF6",
SQLiteProviderFactory.Instance);
SetProviderServices("System.Data.SQLite", (DbProviderServices)SQLiteProviderFactory.Instance.GetService(typeof(DbProviderServices)));
}
}
public class ApplicationContextDB : DbContext
{
static private string dbpath;
static ApplicationContextDB()
{
var exeDir = AppDomain.CurrentDomain.BaseDirectory;
var exeDirInfo = new DirectoryInfo(exeDir);
var projectDir = exeDirInfo.Parent.Parent.FullName;
dbpath= $@"{projectDir}\DBFolder\MyDB.db";
}
public ApplicationContextDB() : base(new SQLiteConnection($"DATA Source={dbpath}"), false)
{
}
public ApplicationContextDB(DbConnection connection) : base(connection, true)
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
base.OnModelCreating(modelBuilder);
}
public DbSet<User> Users{ get; set; }
public DbSet<Work> Works{ get; set; }
}
【问题讨论】:
标签: c# entity-framework sqlite