gpt4 book ai didi

c# - EntityFramework Npgsql DbConfiguration 不起作用

转载 作者:太空宇宙 更新时间:2023-11-03 12:50:10 26 4
gpt4 key购买 nike

我试图先用代码用 Npgsql 配置 EntityFramework。

  • Entity Framework 6.1.3
  • Npgsql 3.0.5

现在,我想通过类来设置自定义配置,让我们看看:

public class DbConfig : DbConfiguration
{
public DbConfig()
{
SetProviderFactory("Npgsql", Npgsql.NpgsqlFactory.Instance);
SetProviderServices("Npgsql", provider: NpgsqlServices.Instance);
SetDefaultConnectionFactory(new NpgsqlConnectionFactory());
}
}

和我的上下文类:

[DbConfigurationType(typeof(DbConfig))]
public class Db: DbContext
{
public virtual DbSet<Products> Products {get;set;}

public Db(DbConnection Connection): base(Connection, true)
{

}

public Db(): base()
{
}

public Db(string connectionString): base(connectionString)
{
}

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{

modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>();
modelBuilder.Conventions.Add<CascadeDeleteAttributeConvention>();
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
modelBuilder.HasDefaultSchema("public");
base.OnModelCreating(modelBuilder);
}
}

然后我尝试访问产品:

class Program
{
static void Main(string[] args)
{
Db.ConfigureMigrations();

string connectionString = "Server=localhost;Port=5432;Database=stockDb;User Id=postgres;Password=123456;";

using (var C = new Db(connectionString))
{
var productos = C.Productos.Count();
Console.WriteLine(productos);
}

Console.WriteLine("listo");
Console.ReadKey();
}
}

但我有一些异常(exception):

  • 'System.Data.Entity.Core.ProviderIncompatibleException'发生在 EntityFramework.dll 中。内部异常:{“提供者未返回 ProviderManifestToken 字符串。”}

或:

初始化字符串的格式不符合从索引 0 开始的规范。

我不知道怎么了。

我得到了引用:

https://msdn.microsoft.com/en-us/data/jj680699.aspx

有人可以帮助我吗?

最佳答案

我解决了这个问题:

问题出在 Db.ConfigureMigrations();行。

如果我对该行的评论没问题,但我需要迁移,那么在我的 ConfigureMigrations 方法中的 Db 上下文中,我需要更改为:

Database.SetInitializer(新 MigrateDatabaseToLatestVersion(真));

仅此而已。谢谢。

关于c# - EntityFramework Npgsql DbConfiguration 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35856151/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com