今天准备说说EntityFramework 6.0+,它与我之前所学的4.0有所区别,自从4.1发布以来,code first 被许多人所钟爱,Dbcontext API也由此时而生。早在学校的时候就听老师说过Db first,Model first 和 Code first ,

没怎么去注意,最近我直接从Db first 跳到了 Code first,去了解了下,个人觉得Model first 和 Code first 没多大区别,英文好的人看以看看http://stackoverflow.com/questions/5446316/code-first-vs-model-database-first,

在这里我也稍微解释下,code first 最大优点就是代码干净简洁,可以使用代码完全控制数据库相关的操作,而不需要到管理系统里面建库建表,也没有那些EntityFramework 4.0里面的那些自动生成的XML文件(看着就头疼,

因为不是自己写的代码),改完下表又得重新搭建一下实体框架(真的很麻烦啊)。但是任何强大的东西都有其一定的弊端,正因为使用如此简单,所以容易造成数据的丢失,特别是像我这种从Db frist 直接跳到 code first 的人如果没有特别了解,

就去跟那些已经使用EF6的人一起做事。这些不是重点,重点是Migration(数据库迁移),数据库迁移对于企业级应用程序来说是再正常不过了吧。拿我们Abp的例子来说吧,首先到ABP官网下载项目https://github.com/aspnetboilerplate,

双击那个NuGet包管理.exe,使用VS2012+打开项目, 在VS工具栏里找到工具==》Nuget程序包管理器==》程序包管理器控制台,先注意看控制台上面的默认项目是不是EntityFramework层,如果不是则选择它,

,改成下面这样

在控制台里面输入:Install-Package EntityFramework 命令,

这样最新版的EF就安装到了你的EntityFramework层,是不是很简单,然后建表,先改下你的配置文件

当然不改的话也是可以的,但是不安全,例子给的是信任连接,也就是说不需要用户名和密码就可以进到你的数据库,然后又到了输入命令的时候了,

如果确定命令没有输入错误,找3个点:1.默认项目是不是EntityFramework,2.启动项目是不是UI层,3.如果前面两个都没问题,那么请关掉VS,重新打开项目,让VS重新加载下项目,不要问我为什么,我也不知道(大神告诉我的),

只能自己去猜测。注意看我用红线画出来的东西,等下告诉你为什么 ,这样表就建好了,

,那个People表是根据我们例子里面的Person类生成的,

看到那个Table特性,就知道为什么生成的表名是People了,凡是加上Table特性的实体类,在运行Update-database命令的时候就会生成对应的表,它的实现原理是反射,至于刚才那个seed方法是什么意思呢,

打开那个Migration文件夹,看到里面的Configuration.cs , 左边那个Seed方法,每次更新数据库最后都会执行这个方法,可以在这里写代码增加记录等等,最后要说说那个Migration了,首先看到上面那个Configuration.cs里面的Configuration方法里面有个AutomaticMigrationEnable属性,此时它是false,也就是说此时是不允许自动迁移的,当然这个Migration文件夹是之前就加上去的,我们先把它删除掉,

,没有了,运行命令Add Migration InitialCreate

看到没有,报错了,错误消息是没有找到迁移配置,这时候我们需要先启动迁移,执行命令:Enable-Migrations

,

Migration文件夹又神奇的出现了,再运行:Add-Migration InitialCreate命令,注意那个InitialCreate,

看到右边那个Migration文件夹里多了一个2015...InitialCreate,看到这里懂了吧,然后我贴一段我从网上找到的图

这个命令我还没用过,不过应该没什么问题。演示用的项目到Github里面去下载,地址:https://github.com/aspnetboilerplate ,我也是初学者,有问题一起探讨,大神请指教。

ABP Migration(数据库迁移)的更多相关文章

  1. 【6】Laravel5.1的migration数据库迁移

    查看Laravel5.1的目录 当你配置好数据库后,在命令行执行下边的操作 php artisan migrate 打开数据库会发现,我们的数据库多了四个表,神奇吧! 打开任意一个migration查 ...

  2. Laravel5.1 Migration数据库迁移文件

    Migration方便于团队开发,它就像数据库的版本控制一样,它的功能就是可以和别人共享你的数据库结构.这么说可能不太好理解,你跟着敲敲就明白了. 0 前提工作-配置数据库 找到你根目录的 .env ...

  3. ABP 框架 数据库底层迁移 Mysql 集群

    技术交流,请加QQ群:538327407 我的各种github 开源项目和代码:https://github.com/linbin524 背景 笔者 目前架构的IOT 项目是使用abp 框架作为后台, ...

  4. Abp数据库迁移注意事项

    前记:昨天下载了一个Abp模板,然后尝试利用EF CodeFirst进行数据库生成操作,然后就是一直报错 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务 ...

  5. MySql 使用 EF Core 2.0 CodeFirst、DbFirst、数据库迁移(Migration)介绍及示例

    dotnet core 2.0 发布已经好几天了,期间也把原来 dotnet core 1.1 的 MVC 项目升级到了 2.0,升级过程还是比较顺利的,变动也不是太多.升级的过程中也少不了 Enti ...

  6. 二、core abp 数据库迁移

    一.数据库迁移-ABP(库) 1.配置链接数据库:  贴以下代码: { "ConnectionStrings": { "Default": "Serv ...

  7. Laravel 5.2数据库--迁移migration

    Laravel中的migrations文件存放的是数据库表文件等结构,可以说是一个跟git差不多的,可以说像是数据库的版本控制器,所以可以叫做迁移.因为它可以很快速的很容易地构建应用的数据库表结构. ...

  8. 2.EF中 Code-First 方式的数据库迁移

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/code-first-migrations-with-entity-framework/ 系列目 ...

  9. laravel数据库迁移(三)

    laravel号称世界上最好的框架,数据库迁移算上一个,在这里先简单入个门: laravel很强大,它把表中的操作写成了migrations迁移文件,然后可以直接通过迁移文件来操作表.所以 , 数据迁 ...

随机推荐

  1. Mac下安装与配置Go语言开发环境

    1.官网下载安装包(需FQ) https://storage.googleapis.com/golang/go1.7.darwin-amd64.pkg 2.配置Go环境变量GOPATH和GOBIN ( ...

  2. Hibernate增删查改语句

    我用的数据库是MySQL,实体类叫Product create table Product ( proId integer not null auto_increment, proName varch ...

  3. MySQL_02之增删改查、PHP数据库操作

    1.数据操作: ①插入记录:  插入单条记录:INSERT tbl_name(字段名称,--) VALUES(字段值,--);  插入多条记录:INSERT tbl_name(字段名称,--) VAL ...

  4. c#字段

    1.C#中是不允许用new操作符创建String对象的,编译器会报错. 2.实例字段:使用new对class创建对象直接赋初始值,不适用于struct slass Rect { public int ...

  5. sql复习第五次

    1.在数据库范围内,关系的每一个属性值是不可分解的 关系中不允许出现重复元组 由于关系是一个集合,因此不考虑元组的顺序 2.笛卡儿积是两个关系的所有元组组合而成的,而等值联接是由笛卡儿积和选择运算组合 ...

  6. 回发或回调参数无效。在配置中使用 pages enableEventValidation=true 或在页面中使用 %@ Page EnableEventValidation=true % 启用了事件验证

    WebForm中回发或回调参数无效问题的解决 解决 .NET中回发或回调参数无效问题的解 该错误的详细提示信息为: 回发或回调参数无效.在配置中使用 <pages enableEventVali ...

  7. OPEN CASCADE Curve Continuity

    OPEN CASCADE Curve Continuity eryar@163.com Abstract. 设计一条复杂曲线时,出于设计和制造上的考虑,常常通过多段曲线组合而成,这就需要解决曲线段之间 ...

  8. etlpy: 并行爬虫和数据清洗工具(开源)

    etlpy是python编写的网页数据抓取和清洗工具,核心文件etl.py不超过500行,具备如下特点 爬虫和清洗逻辑基于xml定义,不需手工编写 基于python生成器,流式处理,对内存无要求 内置 ...

  9. Android随笔之——Activity中启动另一应用

    最近在写语音交互程序,在语音打开应用这块碰到如何用代码控制应用启动的问题.百度了一下,有两种方案:1.获取应用的包名:2.获取应用的包名.入口类名. 之前对两种方案都进行了尝试,发现方案二中存在一个弊 ...

  10. 计时器StopWatch示例

    计时器 StopWatch stwatch = new StopWatch(getClass().getSimpleName()); try{ stwatch.start(joinPoint.getS ...