一、创建Code First模型

1.创建工程,这里我使用的是以.NET 4.0为目标的实体Web应用程序

2.安装Entity Framework

确保已安装NuGet,选择NuGet套件管理员>管理方案的NuGet套件,搜索并安装Entity Framework,

这时,会安装最新版的Entity Framework,并应用到刚新建的工程项目中。

若之前已经安装过Entity Framework,需要将Entity Framework整合到当前项目的话,请选择

NuGet套件管理员>套件管理器主控台,键入:
PM > Install-Package EntityFramework

需要注意的是整合完成后需要手动添加System.Data.Entity dll参考,因为在整合过程中会将其移除。

3.安装Entity Framework Power Tool

工具>扩展管理员中搜索并安装Entity Framework Power Tool

安装完成后在项目名称上右键会出现Entity Framework > Reverse Engineer Code First

4.使用Entity Framework > Reverse Engineer Code First将现有数据库生成domain Class

(至于如何生成数据库,可以新建一个工程并利用Model Designer设计完成,从模型生成数据库)

完成后会出现Model文件夹,且在web.config中会加入一个连接字符串

至此就完成了初始设计工作。

二、使用Migration进行数据模型更改

利用Code First更改数据库模型

1.启用Migration

同样在套件管理器主控台中输入

PM> Enable-Migrations

会加入一个Migration的文件夹

2.修改初始化信息

在生成的DBContext.cs文件中,

修改静态构造函数中的Database.SetInitializer<XXXDBContext>(null);

为Database.SetInitializer<XXXDBContext>(new MigrateDatabaseToLatestVersion<XXXDBContext, 工程项目名称.Migrations.Configuration>("刚建立的连接字符串名称"));

3.加入Migration(XXXSchemaName为任意指定名称)

PM> add-migration XXXSchemaName

成功后显示如下,同时注意到在Migration文件夹下自动生成了一个带有日期的cs文件

4.同步Migrations到数据库

PM> update-database -Verbose

在第一次运行时会创建数据库,但因为数据库中已经存在了该数据库,请更换数据库连接字串或者删除数据表再运行,

之后的update行为则不存在该问题。

5.还原迁移

update-database -TargetMigration:"First School DB schema"

关于Entity Framework使用的简单例子的更多相关文章

  1. Entity Framework Demo(一) 简单搭建环境

    Entity Framwork(实体框架,简称EF)是ORM(Object Relational Mapping,对象映射关系)的一个解决方案. EF允许项目将数据库的表映射为实体,并封装了操作方法, ...

  2. [转]解决:Entity Framework + MariaDb(MySql)中文乱码

    转自:http://fenglongsheng.com/post/6640.html 今天写一MVC4+Entity Framework+Mysql的小例子时,发现中文写到数据库里是N个问号(乱码哦~ ...

  3. Entity Framework 笔记(一)

    Entity Framework概述 EF是一个对象关系映射(ORM)框架,允许开发人员使用特定于域的对象关系型数据,开发人员通常不需要编写大量的数据访问代码.使用EF,开发者可以利用LINQ进行查询 ...

  4. Entity Framework 学习整理(分播客整理)

    MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...

  5. Entity Framework 学习整理

    MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...

  6. 一个最简单的使用Entity Framework 查询SQL 数据库的例子

    1.ADO.NET 3.5 Entity Framework是随着.net framework 3.5一起发布的,确认开发环境版本是大于等于3.5版本 2.确认已经安装了ADO.NET 3.5 Ent ...

  7. 开发 ASP.NET vNext 续篇:云优化的概念、Entity Framework 7.0、简单吞吐量压力测试

    继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之后, 关于云优化和版本控制: 我本想做一下MAC和LINUX的self-ho ...

  8. Entity Framework 简单查询

    前言 首先来简单的复习一下如何使用Code First. 第一步还是先建立一个控制台的应用程序,然后通过Nuget添加Entity Framework.那么同时会给packages.config和Ap ...

  9. 云优化的概念、Entity Framework 7.0、简单吞吐量压力测试

    云优化的概念.Entity Framework 7.0.简单吞吐量压力测试 继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之 ...

随机推荐

  1. jQuery和AngularJS的区别小分析

    最近一直在研究angularjs,最大的感受就是它和之前的jQuery以及基于jQuery的各种库设计理念完全不同,如果不能认识到这点而对于之前做jQuery开发的程序员,去直接学习angularjs ...

  2. YARN-MR 大数据第二天

    大数据第二天 1.YARN(管理和调度集群中的各类资源) 1.1 产生的背景: 1.直接源于MR版本1的缺陷(如:单点故障.难以支持MR之外的计算框架等) 2.多计算框架各自为站,数据共享困难(如:M ...

  3. Oracle协议适配器错误解决办法

    在Oracle中新建了一个数据库,今天把它删了之后再登录SQL*PLUS就登不上去了,出现ORA-12560:TNS:协议适配器错误. ORA-12560: TNS: 协议适配器错误的解决方法 造成O ...

  4. JSON.stringify() / JSON.parse()

    JSON.stringify() 这个方法可以把javascript对象转换成json字符串. JSON.parse() 这个方法可以把 json 字符串转换成 javascript对象. [下面来看 ...

  5. NOI 题库 7624

    7624  山区建小学 描述 政府在某山区修建了一条道路,恰好穿越总共m个村庄的每个村庄一次,没有回路或交叉,任意两个村庄只能通过这条路来往.已知任意两个相邻的村庄之间的距离为di(为正整数),其中, ...

  6. NOIP2012拓展欧几里得

    拉板题,,,不说话 我之前是不是说过数据结构很烦,,,我想收回,,,今天开始的数论还要恶心,一早上听得头都晕了 先来一发欧几里得拓展裸 #include <cstdio> void gcd ...

  7. 李洪强iOS经典面试题139-Swift

    李洪强iOS经典面试题139-Swift Swift 网上有很多Swift的语法题,但是Swift现在语法还未稳定,所以在这里暂时不贴出语法题,可以自行搜索. Swift和Objective-C的联系 ...

  8. Web 开发基础

    C/S:winform   WPF 数据是存在其它的电脑上或服务器上需要从服务器上下载相应的数据,在本地电脑上的客户端里进行加工 数据加工的过程是在用户电脑上执行,会对用户的电脑配置有所要求 B/S: ...

  9. android获取本地图片并显示图片

    import java.io.FileNotFoundException; import android.content.ContentResolver; import android.content ...

  10. Tomcat启动后,从spring容器中获取Bean和ServletContext

    public static Object getBean(String beanName){ ApplicationContext context = ContextLoader.getCurrent ...