码迷,mamicode.com
首页 > 数据库 > 详细

实体框架 (EF) 入门 => 二、在全新的数据库中使用 Code First

时间:2017-11-26 14:01:24      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:user   连接   为什么   first   页面   def   特性   直接   回车   

学习资料:http://msdn.microsoft.com/zh-cn/data/jj193542

视频建立的控制台应用程序,我在这里使用MVC。

一、非常有磁性的,非常优雅

很喜欢看这个人的视频,虽然我听不太懂,也不知道他叫什么。他的声音非常有磁性,让我。。。,让我。。。。。。,百听不厌。

看到了吗?他一边讲解,代码就一边流畅的显示在屏幕上,让你懂得,什么是优雅。

原来也看过,但发现动手时还是无从下手,所以,不仅应该学习代码,还应该学习流程,先做什么,后做什么,为什么要这样做。

二、建立MVC项目

环境:vs.net2013 sql2008 ef6.1 mvc5

技术分享图片

身份验证选择个人用户账户,只是免去自己添加验证JS的麻烦,实际开发使用  无身份验证。

技术分享图片

技术分享图片

三、创建模型

就像以前要先创建数据库一样,现在是先创建模型。

技术分享图片

因为使用的是个人身份验证,所以系统自动生成一些Controler/Model/View,不用管它。

技术分享图片

技术分享图片

技术分享图片

代码是我复制的,说明如下:

1、BlogId 这样写能与外键列名保持一致,感觉这样好点

2、类名用的是Blog,而不是Blogs。实体一般用单数,在生成数据表是,会自动添加成复数表名 Blogs。

3、Post类还未建立,所以报错。但现在我们使用的是Code First,可以这样写,因为我们现在也不编译。在写一个实体类时,即使没有设计文档,心里也应该有个框框了,要建哪些实体,实体之间有什么关联。

4、Post类一样使用单数形式,而集合使用的是同名复数 Posts 。

5、virtual 用于延迟加载,也就是你在使用Blog实体对象时,如果不使用相关联的Post表中的数据,系统就不加载,你使用的时候,才到数据库查询相应的Post数据。

这样可能要访问两次或多次数据库,所以一般不会使用延迟加载,而是在需要时将需要的字段一次性取回。

因为是CodeFirst,所以,写实体属性时,应该也顺便将常规的特性加上:

在Name上面输入[],在里面输入Display ,我就会拼这个单词,所以,每次都用她      技术分享图片

在Display上右键,导入命名空间。

技术分享图片

也可以这样,输入完Display后按Ctrl + . ,然后回车,爽不?

技术分享图片

弄成这样:

技术分享图片

加上长度(20)还是有点用的,否则如果不小心输入了100个字符,不仅没有必要,你还要考虑列表显示的问题了。

技术分享图片

四、创建上下文

上面只是建立了两个实体类,如果要与数据库关联,还需要创建上下文。

技术分享图片

技术分享图片

技术分享图片

五、安装(更新)EF,需要联网更新

技术分享图片

若果你的VS界面下方没有 程序包管理控制台 ,按下面方式打开:

技术分享图片

六、编辑web.config,添加连接字符串

技术分享图片

 

下面该干嘛了?再看看视频

七、生成界面

因为是全新数据库,所以,建立了实体对象,并与上下文关联后,就可以直接写界面了。

先编译一下。

技术分享图片

技术分享图片

技术分享图片

八、删除原有数据库

这时程序未运行,所以还不会生成数据库。

先把原来的删掉,全新的吗,原来怎么应该有。

技术分享图片

真真正正,干干净净

九、运行列表页面

技术分享图片

技术分享图片

空的

十、添加记录

技术分享图片

技术分享图片

十一,查看数据库

刚才没用这个是因为连不上。

技术分享图片

技术分享图片

技术分享图片

 

十二、模型更改

1、Enable-Migrations

2、修改实体对象

技术分享图片

3、Add-Migration AddUrl

4、Update-Database

技术分享图片

十三、添加新模型

技术分享图片

十四、将实体添加进上下文

技术分享图片

十五、Add-Migration AddUser

十六、Update-Database

技术分享图片

 

 
 

实体框架 (EF) 入门 => 二、在全新的数据库中使用 Code First

标签:user   连接   为什么   first   页面   def   特性   直接   回车   

原文地址:http://www.cnblogs.com/webenh/p/7898667.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!