网站标题title为什么不能频繁的改,hoperun企业邮箱,成免费crm软件排名,网站需求怎么写一些介绍 CodeFirst是EntityFrameworks的一种开发模式#xff0c;即代码优先#xff0c;它以业务代码为主#xff0c;通过代码来生成数据库#xff0c;并且加上migration的强大数据表比对功能来生成数据库版本#xff0c;让程序开发人员不用维护数据库的变更#xff0c;而…一些介绍 CodeFirst是EntityFrameworks的一种开发模式即代码优先它以业务代码为主通过代码来生成数据库并且加上migration的强大数据表比对功能来生成数据库版本让程序开发人员不用维护数据库的变更而直接维护migration即可在它里面有你当前版本和过去历史版本的所有变更记录 1通过EF-CodeFirst自己帮我们建立了数据库初始化的数据表 第一次建立数据模型运行程序自动建立数据库和数据表并执行对应的初始化工作 数据模型 数据初始化 EF在LindAgile里的注册 数据库第一次被创建数据表名的名称可以控制它的单数和复数形式 protected override void OnModelCreating(DbModelBuilder modelBuilder){// 注意表单复数形式时实体不能有下划线必须是单词modelBuilder.Conventions.RemoveSystem.Data.Entity.ModelConfiguration.Conventions.PluralizingTableNameConvention(); } 其中__MigrationHistory表它是数据变更的数据表体现了数据库的历史 开始数据迁移 这时我们看解决方案里没有migrations文件夹因为这时你没有开启变更计划 当开启变更后才会出现这个文件夹 Enable-Migrations 然后在项目中就看到了migrations文件夹它将存储我们数据库的变更记录 我们如果新添加了数据实体DO或者修改了原来的实体然后希望升级一个变更记录可以使用add-migration 变更名随便写 然后在我们项目的Migrations目录会多一个变更文件它以时间戳开头我们在变更执行时这个时间戳是它顺序执行的关键 把模型的变更更新到数据库 同时我们看一个数据表__MigrationHistory它没有发生变化这是因为我们没有把变更更新到数据库如果希望更新到数据库可以使用update-database来实现如果不加版本号默认更新的是最新的变更记录它会包括之前的变更代码在更新时它会与数据表__MigrationHistory里的变更记录进行对比如果已经更新过了就不会执行这个版本而只会向后更新 执行完成后我们再看一下数据表的变化它也会多一条最新的变更记录以后我们再有数据表变更就使用这个方法即可EF-migration只要我们好好用它只会使我们的开发便得更快捷 把模型的变更成SQL脚本以便在生产环境中使用 Update-Database -Script -SourceMigration: $InitialDatabase -TargetMigration:init 上面代码执行后会生成一个SQL文件我们拿这个文件可以到生产环境中去执行就完成了数据库的更新 文章转载至:http://www.cnblogs.com/lori/p/7065698.html转载于:https://www.cnblogs.com/LonelyCode/p/7072888.html