关于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)>之 ...
随机推荐
- Linux常用命令学习2---(文件搜索命令locate find、命令搜索命令whereis which、字符串搜索命令grep、帮助命令man)
1.文件搜索命令:locate [文件名] 在后台数据库中按文件名搜索,搜索速度比find快,耗费资源更少 例子:locate test.txt,就会显示文件名包含 test.txt的所 ...
- http返回码301、302、307、305含义和区别
301永久重定向,302暂时移动,seo对301和302的处理不一样: 301和302会出现数据丢失问题,重定向后请求数据丢失: 307临时重定向,数据不会丢失:
- psql-10权限和事务
用户和角色 用户和角色在整个数据库实例中都是全局的;
- iOS 开发技巧收藏贴 链接整理
54个技巧 57个技巧 正则表达式
- eclipse从下载到使用
经常遇到有同学问我: 为啥我的eclipse没有你说的那个东西? 那是咱两选择的平台不一样 我的eclipse为啥和你的那个长的不一样? 那是咱两选择的版本不一样 为什么我的打开报XXX错误? ... ...
- 推荐轻量高效无依赖的开源JS插件和库
目录 图片 布局 音频视频 编辑器 轮播图 弹出层 表单 存储 动画 时间 其它 CDN 图片 baguetteBox.js - 是一个简单易用的响应式图像灯箱效果脚本.demo Lightgalle ...
- swif-throws异常抛出
import UIKit enum VendingMachineError: Error { case invalidSelection //选择无效 case insufficientFunds(c ...
- ubuntu开启SSH服务
SSH分客户端openssh-client和openssh-server 如果你只是想登陆别的机器的SSH只需要安装openssh-client(ubuntu有默认安装,如果没有则sudo apt-g ...
- Unity运行时检测Altas使用情况
UI贴图在游戏中内存大小中占的分量非常非常大,尤其对于前期对UI没有规划的项目,无论是包量还是内存大小都是需要花费很多时间去优化.如果涉及到战斗场景和逻辑场景的情况下,常用的做法就是把两个场景使用的a ...
- 时间js转换方法Date("149...") 转成 2016-7-12 21:23:34 009
function timeFormatter(value) { var da = new Date(parseInt(value.replace("/Date(", &q ...