一、创建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. HTML表单提交

    <!DOCTYPE html> <!--当前文档为html5--> <html> <head> <!--设置文档编码--> <meta ...

  2. python学习笔记(2)

    1.for循环 用户按照顺序循环可迭代对象中的内容. li = [11,22,33,44] for i in li: print i for循环的else 此功能目前只有for循环里面有发现. 具体条 ...

  3. Logistic回归的使用

    Logistic回归的使用和缺失值的处理 从疝气病预测病马的死亡率 数据集: UCI上的数据,368个样本,28个特征 测试方法: 交叉测试 实现细节: 1.数据中因为存在缺失值所以要进行预处理,这点 ...

  4. Android 笔记 day1

  5. C++中随机数和不重复的随机数

    随机数 int rand (); rand函数返回一个0-32767之间的一个伪随机整数,32767可以由宏RAND_MAX表示,该函数需要头文件<stdlib.h>. 常用的是如何生成一 ...

  6. 根据google地图抓去全国信息- 抓去全国小区以及新建楼盘信息

    本案例由于google每天每个账户能post20000次所以我们需要相对较长的时间来抓去google的数据信息. 主要思路:通过一定的zoom一个相对较大的zoom.我们尽可能的搜索我们的所有数据. ...

  7. BZOJ 2460 [BeiJing2011]元素 ——线性基

    [题目分析] 线性基,由于最多有63个,只需要排序之后,动态的去维护线性基即可. [代码] #include <cstdio> #include <cstring> #incl ...

  8. 分配问题与Hungarian算法

    分配问题与Hungarian算法 分配问题 指派问题 匈牙利算法 匈牙利方法是一种能够在多项式时间内解决分配问题(assignment problem)的组合优化算法.它由Harold Kuhn 与1 ...

  9. 【SDOI2009】HH的项链

    洛谷题目链接 题意: 给定一个长5w静态的序列,询问20w次,每次询问查找一个区间内的元素种类数 染色问题神烦啊,最近刚会做,感觉都可以用统一的方法 首先要算出与一个元素相同的最邻近的上一个元素的位置 ...

  10. Java_类的热替换

    转自:http://www.ibm.com/developerworks/cn/java/j-lo-hotswapcls/#ibm-pcon Java ClassLoader 技术剖析 在本文中,我们 ...