关于Entity Framework使用的简单例子
一、创建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使用的简单例子的更多相关文章
- Entity Framework Demo(一) 简单搭建环境
Entity Framwork(实体框架,简称EF)是ORM(Object Relational Mapping,对象映射关系)的一个解决方案. EF允许项目将数据库的表映射为实体,并封装了操作方法, ...
- [转]解决:Entity Framework + MariaDb(MySql)中文乱码
转自:http://fenglongsheng.com/post/6640.html 今天写一MVC4+Entity Framework+Mysql的小例子时,发现中文写到数据库里是N个问号(乱码哦~ ...
- Entity Framework 笔记(一)
Entity Framework概述 EF是一个对象关系映射(ORM)框架,允许开发人员使用特定于域的对象关系型数据,开发人员通常不需要编写大量的数据访问代码.使用EF,开发者可以利用LINQ进行查询 ...
- Entity Framework 学习整理(分播客整理)
MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...
- Entity Framework 学习整理
MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...
- 一个最简单的使用Entity Framework 查询SQL 数据库的例子
1.ADO.NET 3.5 Entity Framework是随着.net framework 3.5一起发布的,确认开发环境版本是大于等于3.5版本 2.确认已经安装了ADO.NET 3.5 Ent ...
- 开发 ASP.NET vNext 续篇:云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之后, 关于云优化和版本控制: 我本想做一下MAC和LINUX的self-ho ...
- Entity Framework 简单查询
前言 首先来简单的复习一下如何使用Code First. 第一步还是先建立一个控制台的应用程序,然后通过Nuget添加Entity Framework.那么同时会给packages.config和Ap ...
- 云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
云优化的概念.Entity Framework 7.0.简单吞吐量压力测试 继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之 ...
随机推荐
- 关于Qt creator 无法使用fcitx输入中文的问题折腾
环境: 系统ubuntu16.04amd64,qt5.4.2 安装完qt5.4后,在编写代码时,发现无法输入中文,离开qt creator 就立刻正常.原因似乎是qt对fcitx支持. 解决方法我是参 ...
- 【Python】 属性的 get 与 set 方法
在C#里面,属性的get 与 set 非常简单方便. public class bird { public int age { get;set; } public bool isadult { get ...
- PHP CURL模拟提交数据 攻击N次方
public function actionCurl(){ $data['DATA']='{"NAME":"c","LEGEND":&quo ...
- 以前用SQL实现的机构职能树,再看看
DECLARE CNT NUMBER; TMP ); vtmp ); ltmp1 ); ltmp2 ); ltmp3 ); ltmp4 ); NTMP NUMBER; CURSOR CSR_TEST ...
- tomcat配置详解/优化方案
Service.xml Server.xml配置文件用于对整个容器进行相关的配置. <Server>元素:是整个配置文件的根元素.表示整个Catalina容器. 属性:className: ...
- appium依赖pom文件注解
<!-- appium部分 依赖--> <dependency> <groupId>io.appium</groupId> <artifactId ...
- requirejs的用法(二)
这个系列的第一部分和第二部分,介绍了Javascript模块原型和理论概念,今天介绍如何将它们用于实战. 我采用的是一个非常流行的库require.js. 一.为什么要用require.js? 最早的 ...
- 畅通工程[HDU1863]
畅通工程 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submissio ...
- CodeForces 279D The Minimum Number of Variables 题解
题目大意: 有一组n个不相同的数字组成数串:a1,a2,a3-an. 1.一个数组b. 2.第一个操作我们将b0的值赋为a1.之后我们有n-1个操作,第k次操作我们将by=bi+bj(y,i,j可能相 ...
- 【BZOJ1180】: [CROATIAN2009]OTOCI & 2843: 极地旅行社 LCT
竟然卡了我....忘记在push_down先下传父亲的信息了....还有splay里for():卡了我10min,但是双倍经验还是挺爽的,什么都不用改. 感觉做的全是模板题,太水啦,不能这么水了... ...