Entity Framework 二
本篇主要介绍:创建了实体数据模型,生成了那些文件以及其代表意义
创建实体数据模型
上一篇的最后,我们创建了数据库,现在我们利用数据库来生成我们的实体数据模型,这种形式我们称为数据库优先,后面会介绍代码优先。
①新建一个控制台,版本设置为4.5

②添加 - >单击新建项目,从弹出菜单中选择ADO.NET实体数据模型,给新项目名称“School”,然后单击添加按钮。

③选择模型:

④连接到数据库:

⑤全部勾上

如果数据库中的表名是复数,生成的对象名称复数或单数化 复选框会单独化一个实体集名称。例如,如果SchoolDB具有Students表名,那么entityset将是单数Student。
同样,如果表格与其他表格有一对多或多对多的关系,则模型之间的关系将被复数化。例如,学生与课程表具有多对多的关系,所以学生实体集合将具有用于收集课程的多个属性名称“课程”。
第二个复选框“ 在模型中包含外键列”包含外键属性,用于表示外键。例如,Student表与标准表具有一对多的关系。所以每个学生只有一个标准。为了在模型中表示这个,Student实体集包含标准导航属性的StandardId属性。如果这个复选框未被选中,那么它将只包含Standard属性,但不包含Student实体集中的StandardId。
第三个复选框,将所选存储过程和函数导入到实体模型中,自动为存储过程和函数创建函数导入。您不需要手动导入,如实体框架5.0之前所必需的。
⑥生成 School.edmx

⑦双击School.edmx打开设计器

实体-表映射
EDM中的每个实体都与数据库表映射。您可以通过右键单击EDM设计器中的任何实体来检查实体表映射 - >选择表映射。另外,如果您从设计器更改实体的任何属性名称,则表映射将自动反映该更改。

上下文和实体
每个实体数据模型为EDM中包含的每个数据库表生成一个上下文类和实体类。展开School.edmx并查看两个重要文件
{EDM Name} .Context.tt 和 {EDM Name} .tt:

School.Context.tt:无论何时更改实体数据模型(.edmx文件),此T4模板文件都会生成一个上下文类。您可以通过展开School.Context.tt来查看上下文类文件。上下文类位于{EDM Name} .context.cs文件中。默认的上下文类名是{DB Name} +实体。例如,SchoolDB的上下文类名是SchoolDBEntities,那么上下文类是从实体框架中的DBContext类派生的。(在EF 5.0之前,它是从ObjectContext派生的。)

School.tt:School.tt是一个T4模板文件,为每个数据库表生成实体类。实体类是POCO(普通旧CLR对象)类。下面的代码片段显示了学生实体。

您可以在XML视图中打开此EDM设计器,您可以在XML视图中一起查看EDM的所有三个部分 - 概念架构(CSDL),存储架构(SSDL)和映射架构(MSL)。
右键单击School.edmx - >单击“选择打开方式 ————》 XML编辑器打开”

模型浏览器
视图--->其他窗口---->实体数据模型浏览器 (如果在其他窗口里面没有看到实体模型浏览器,请你双击School.edmx)
需要把这个打开,实体模型浏览器才会出现


关系图:模型浏览器包含EDM的可视化图表。我们已经看到由EDM创建的默认视觉图。如果您的应用程序拥有大量实体,您也可以为一个EDM 创建多个图表。
实体类型:实体类型列出了所有映射到数据库表的类类型。
复杂类型:复杂类型是由EDM生成的包含存储过程,表值函数等的结果的类。这些复杂类型是用于不同目的的定制类。
枚举类型:枚举类型列出在实体框架中用作Enum的所有实体。
关联:关联列出实体类型之间的所有外键关系。
函数导入:函数导入列出将被映射到存储过程,表值函数等的所有函数。存储过程和表值函数将被用作函数而不是EF中的实体。
.Store:存储表示数据库模式(SSDL)。
Entity Framework 二的更多相关文章
- Entity Framework二、 模型优先 ,ObjectContext类
https://www.cnblogs.com/ejiyuan/archive/2009/05/27/1490786.html 1.ObjectContext 封装.NET Framework和数据库 ...
- Entity Framework (二) 查询
待完善-------------------------------------- ----------- base 关键字用于从派生类中访问基类的成员: 调用基类上已被其他方法重写的方法. 指定创建 ...
- entity framework 新手入门篇(1)-建立模型
entity framework是微软官方免费提供给大家的一套ORM(Object Relational Mapping对象关系映射)解决方案.它不仅可以帮助我们解决数据缓存的问题,还能在最小的开销下 ...
- Entity Framework 程序设计入门二 对数据进行CRUD操作和查询
前一篇文章介绍了应用LLBL Gen生成Entity Framework所需要的类型定义,用一行代码完成数据资料的读取, <LLBL Gen + Entity Framework 程序设计入门& ...
- C# ORM—Entity Framework 之Code first(代码优先)(二)
一.Entity Framework Code first(代码优先)使用过程 1.1Entity Framework 代码优先简介 不得不提Entity Framework Code First这个 ...
- Entity Framework Code First (二)Custom Conventions
---------------------------------------------------------------------------------------------------- ...
- Entity Framework学习笔记(二)----CRUD(1)
请注明转载地址:http://www.cnblogs.com/arhat 这篇文章老魏和大家分享一下Entity Framework的CRUD操作,在这之前呢,老魏先说一下老魏对EF的一个整体的认识, ...
- Mvc5+Entity Framework6 之二----在MVC中用Entity Framework实现基本的CRUD
目标:创建控制器和视图的代码,实现CRUD(创建,读取,更新,删除)功能 创建一个详细信息页 控制器为Students的Index页生成的代码排除Enrollments属性在外,因为该属性中关联着一个 ...
- Entity Framework笔记(二)
前几日学习了在VS2010Console项目中使用Entity Framework,并且使用Code First模式.通过编写Model类,来生成数据库对应的表.并且,往表中写入数据以及获取表中的所有 ...
随机推荐
- shell中if的可判断的类型
-d :判断制定的是否为目录-z:判断制定的变量是否存在值-f:判断制定的是否为文件-L:判断制定的是否为符号链接-r:判断制定的是否可读-w:判断制定的是否可写-x:判断存在的对象是否可以执行!:测 ...
- ubuntu-14.10 输入法切换设置
1. 设置---系统设置 2. 语言支持---添加或删除语言---汉语 3. 关闭,系统设置找到 文本输入 4. 可以添加.删除,以及切换方式
- mysql的引擎和锁
- jQuery:mouseover and Increase the Size of an Image
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- HDU 5215 Cycle(dfs判环)
题意 题目链接 \(T\)组数据,给出\(n\)个点\(m\)条边的无向图,问是否存在一个奇环/偶环 Sol 奇环比较好判断吧,直接判是否是二分图就行了.. 偶环看起来很显然就是如果dfs到一个和他颜 ...
- css box-shadow知识点及多重边框
box-shadow() 参数: h-shadow:水平阴影的位置.允许负值. v-shadow:垂直阴影的位置.允许负值. blur:模糊距离. spread:扩张半径(可正可负.投影面积则可大可小 ...
- html学习笔记:基本结构,排列清单,表格
<html> <head> 基本结构,排列清单,表格 <title></title> <!--文件标题声明--> <base> ...
- html跨域获取数据
a.com下的a.html,需要嵌入b.com下的b.html.这时建一个静态页面c.html将c.html放到a.com服务器中.b.html在嵌入c.html.这样,将参数值传输到c.html中, ...
- 使用HTML5 canvas做地图(2)瓦片以及如何计算的
上一篇也说到瓦片,我们为什么使用瓦片?这一篇主要是关于如何拼接地图? 下面的一张图,可以一眼明了,地图是如何切割以及拼接的. 瓦片信息 瓦片信息包括切图原点,瓦片大小,格式,分辨率以及分辨率级别等. ...
- ArcGIS Enterprise 10.5.1 静默安装部署记录(Centos 7.2 minimal)- 3、安装Portal for ArcGIS
安装Portal for ArcGIS 解压portal安装包,tar -xzvf Portal_for_ArcGIS_Linux_1051_156440.tar.gz 切换到arcgis账户静默安装 ...