栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何创建初始化程序来创建和迁移mysql数据库?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何创建初始化程序来创建和迁移mysql数据库?

我认为您就在那儿-
您可以查找

MigrateDatabaseToLatestVersion
(它的开源http://entityframework.preplex.com/)的源代码-
相当简单,它所做的几乎就是
DbMigrator
- 尽我所能看到。

您似乎要做的只是将两者合并-使用一个或另一个作为基础,在其中添加其他功能-我认为应该可以正常工作。

class CreateAndMigrateDatabaseInitializer<TContext, TConfiguration> : CreateDatabaseIfNotExists<TContext>, IDatabaseInitializer<TContext>     where TContext : DbContext    where TConfiguration : DbMigrationsConfiguration<TContext>, new(){    private readonly DbMigrationsConfiguration _configuration;    public CreateAndMigrateDatabaseInitializer()    {        _configuration = new TConfiguration();    }    public CreateAndMigrateDatabaseInitializer(string connection)    {        Contract.Requires(!string.IsNullOrEmpty(connection), "connection");        _configuration = new TConfiguration        { TargetDatabase = new DbConnectionInfo(connection)        };    }    void IDatabaseInitializer<TContext>.InitializeDatabase(TContext context)    {        Contract.Requires(context != null, "context");        var migrator = new DbMigrator(_configuration);        migrator.Update();        // move on with the 'CreateDatabaseIfNotExists' for the 'Seed'        base.InitializeDatabase(context);    }    protected override void Seed(TContext context)    {    }}

这样称呼…

Database.SetInitializer(new CreateAndMigrateDatabaseInitializer<GumpDatabase, YourNamespace.Migrations.Configuration>());

…实际上,像您所做的那样覆盖它(因为它是通用实现)

CreateDatabaseIfNotExists
(您只需要为Configuration添加额外的“
param”),然后提供“ Seed”即可。

class GumpDatabaseInitializer : CreateAndMigrateDatabaseInitializer<GumpDatabase, YourNamespace.Migrations.Configuration>{    protected override void Seed(GumpDatabase context)    {        context.Database.ExecuteSqlCommand("CREATE UNIQUE INDEX Name ON Stations (Name)");    }}

…并称其为

Database.SetInitializer(new GumpDatabaseInitializer());

编辑: 基于注释-
DbMigrator不应运行两次。它总是检查(花费一些时间)并进行“空白”更新并继续。但是,以防万一,如果您想在输入之前删除并“检查”-这应该起作用(更改上面类似的部分)…

var migrator = new DbMigrator(_configuration);if (!context.Database.CompatibleWithModel(throwIfNometadata: false))    if (migrator.GetPendingMigrations().Any())        migrator.Update();

(这是多余的/仔细检查-if-s之一就足够了。在这里稍作休息-
看看Db迁移后到底发生了什么,它不应该进入。如我所提到的,当我将Db迁移后,它可以正常工作测试一下。

编辑:

InitializeDatabase
用… 替换内部

var doseed = !context.Database.Exists();// && new DatabaseTableChecker().AnyModelTableExists(context);// check to see if to seed - we 'lack' the 'AnyModelTableExists' - could be copied/done otherwise if needed...var migrator = new DbMigrator(_configuration);// if (doseed || !context.Database.CompatibleWithModel(throwIfNometadata: false))    if (migrator.GetPendingMigrations().Any())        migrator.Update();// move on with the 'CreateDatabaseIfNotExists' for the 'Seed'base.InitializeDatabase(context);if (doseed){    Seed(context);    context.SaveChanges();}

这可以解决(半路)不播种的情况-如果首先进行迁移。迁移必须是第一位的,否则您会遇到问题。

您仍然需要正确地进行操作-这不是您可能需要的所有内容的要点-但如果有MySQL等问题,这里可能还有更多工作要做。

注意: 如果您有数据库,则仍无法播种,但它为空。问题是两种不同的初始化器混合使用。因此,您必须解决此问题-通过实施Create
…在内部执行的操作(该调用我们不能调用)或其他操作。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/394050.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号