zoukankan      html  css  js  c++  java
  • EF架构~CodeFirst数据迁移与防数据库删除

    回到目录

    本文介绍两个概念,防数据库自动删除,这是由于在code first模式下,当数据实体发生变化时,会对原来数据库进行删除,并将新数据表添加进来,但这对于我们的运营环境数据库,是万万不能接受的,第二个问题是数据迁移问题,当你有新的实体建立后,如何响应到数据库,这成为一个问题,当然实现也很简单,我们直接使用migrations工具即可.

    一 防数据库删除

    将你的业务DbInitializer的基类改成CreateDatabaseIfNotExists即可解决这个问题,这是在数据初始化时需要做的事,一般地,我们会选择当实体有变化时,自动更新数据库,但这样做影响比较大,所以我们不提倡使用.

      public class ManagerInitializer : CreateDatabaseIfNotExists<ManagerContext>
        {
            protected override void Seed(ManagerContext context)
    {     
    //初始化代码 } }

    二 数据迁移

    这个问题也是必须要解决的,我们的实体添加后,数据库并没有对应的表,我们就需要使用migrations命令来对数据库进行更新,具体操作如下

    1 开启migrations功能

    enable-migrations -force

    2 添加迁移版本

    add-migration 名称后缀

    我们每次修改实体后,都应该使用这个add-migration来升级历史版本

    3 更新数据库

    update-database

    4 程序运行成功后,如图

    这时你查看自己的数据库,新加的实体已经自动添加到数据库了,呵呵.

    值得注意的是,通过这种方法进行数据库迁移,数据库的原数据是不会丢失的,即使你在原来的表上添加字段,老数据也不会丢,新字段会有默认值.

    对于EF7来说,它只支持Code First模式,所以这种模式在dotnet框架里将会成为主流!

    补充:

    最近有朋友问我在服务器上如何进行数据的更新,即在生产环境如何使用迁移,可以读一下我的这篇文章<EF架构~CodeFirst生产环境的Migrations>

    回到目录

  • 相关阅读:
    WeChat小程序开发(五、前端总结)
    前端实现复制到剪贴板
    vue的自定义指令含大写字母会失效
    如何把网页变成黑白
    原生JS offsetX和offsetY引起抖动
    jQuery中prop方法和attr方法区别
    Js for循环中的闭包 & let和var的混用对比
    html和body标签默认高度为0带来的影响
    JS字符串数组降维
    CSS浮动流脱标的字围现象
  • 原文地址:https://www.cnblogs.com/lori/p/5646382.html
Copyright © 2011-2022 走看看