实体框架代码首先 - Firebird迁移:否MigrationSqlGenerator? [英] Entity Framework Code First - Firebird migration: No MigrationSqlGenerator?
问题描述
private void btnUpdateDb_Click(object sender,EventArgs e)
{
DbConnection userDBConnection = ClassBasicRepository.GetDBConnection();
var configuration = new Configuration();
configuration.TargetDatabase = new DbConnectionInfo(
userDBConnection.ConnectionString,
FirebirdSql.Data.FirebirdClient);
DbMigrator migrator = new DbMigrator(configuration);
migrator.Update();
}
DbMigrationsConfiguration:
public sealed class配置:DbMigrationsConfiguration< BaseDbContext>
{
public Configuration()
{
AutomaticMigrationsEnabled = false;
//SetSqlGenerator(\"FirebirdSql.Data.FirebirdClient,new FirebirdSql.Data.Entity。???);
}
protected override void Seed(BaseDbContext context)
{
MigrationsAssembly = Assembly.GetExecutingAssembly();
MigrationsNamespace =MyServices.Data.Migrations;
}
}
migrator.Update()给了我以下例外:
没有为提供商FirebirdSql.Data.FirebirdClient找到MigrationSqlGenerator。使用目标迁移配置类中的SetSqlGenerator方法来注册其他SQL生成器。
我必须在配置中指定一个MigrationSQLGenerator。但是我在FirebirdClient.dll中找不到。我发现唯一的解决办法是自行重写:
https://github.com/mrward/entityframework-sharpdevelop/blob/master/src/EntityFramework/Migrations/Sql/SqlCeMigrationSqlGenerator.cs
一个Firebird特定的MigrationSQLGenerator是否真的有必要,而不是不提供迁移?
我的环境:
EntityFramework 5.0.0
.NET 4.5
FirebirdClient 3.0.2.0
目前不支持迁移。实际上您可以使用迁移,但是您必须生成脚本并将其更改为适合Firebird风味SQL。
I'm searching for a way to update my firebird-database. I tried using migrations:
private void btnUpdateDb_Click(object sender, EventArgs e)
{
DbConnection userDBConnection = ClassBasicRepository.GetDBConnection();
var configuration = new Configuration();
configuration.TargetDatabase = new DbConnectionInfo(
userDBConnection.ConnectionString,
"FirebirdSql.Data.FirebirdClient");
DbMigrator migrator = new DbMigrator(configuration);
migrator.Update();
}
DbMigrationsConfiguration:
public sealed class Configuration : DbMigrationsConfiguration<BaseDbContext>
{
public Configuration()
{
AutomaticMigrationsEnabled = false;
//SetSqlGenerator("FirebirdSql.Data.FirebirdClient", new FirebirdSql.Data.Entity.???);
}
protected override void Seed(BaseDbContext context)
{
MigrationsAssembly = Assembly.GetExecutingAssembly();
MigrationsNamespace = "MyServices.Data.Migrations";
}
}
"migrator.Update()" gives me the following Exception:
No MigrationSqlGenerator found for provider 'FirebirdSql.Data.FirebirdClient'. Use the SetSqlGenerator method in the target migrations configuration class to register additional SQL generators.
I have to specify a MigrationSQLGenerator in the Configuration. But I can't find it in the FirebirdClient.dll. The only solution I found was to rewrite it on my own: https://github.com/mrward/entityframework-sharpdevelop/blob/master/src/EntityFramework/Migrations/Sql/SqlCeMigrationSqlGenerator.cs
Is a Firebird specific MigrationSQLGenerator really necessary and not not provided to enable migrations?
My Environment: EntityFramework 5.0.0 .NET 4.5 FirebirdClient 3.0.2.0
Migrations are currently not supported. Actually you can use migrations, but you'll have to generate the script and change it to fit Firebird-flavor SQL.
这篇关于实体框架代码首先 - Firebird迁移:否MigrationSqlGenerator?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!