2016-03-07 2 views
1

Im пытается настроить EntityFramework с Npgsql с кодом в первую очередь.EntityFramework Npgsql DbConfiguration не работает

  • EntityFramework 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(); 
    } 
} 

Но у меня есть некоторые исключения:

  • 'System.Data.Entity.Core.ProviderIncompatibleException' произошло в EntityFramework.dll. внутреннее исключение: { «Поставщик не возвращает строку ProviderManifestToken.»}

или:

Формат строки инициализации не соответствует спецификации, начиная с индекса 0.

И я не знаю, что случилось.

Я получил ссылку:

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

csomeone может мне помочь?

ответ

0

Я решил это:

Проблема с Db.ConfigureMigrations(); линия.

если я комментировать эту линию все в порядке, но мне нужны миграции, то в моем Db контексте в моем методе ConfigureMigrations мне нужно изменить для:

Database.SetInitializer (новый MigrateDatabaseToLatestVersion (истина));

И это все. Спасибо.