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类,来生成数据库对应的表.并且,往表中写入数据以及获取表中的所有 ...
随机推荐
- pat1004. Counting Leaves (30)
1004. Counting Leaves (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A fam ...
- Cannot initialize Cluster. Please check your configuration for mapreduce.framework.name
添加一下依赖 <dependency> <groupId>org.apache.hadoop</groupId> <artifactId>hadoop- ...
- (转载)C#获取当前应用程序所在路径及环境变量
一.获取当前文件的路径 string str1=Process.GetCurrentProcess().MainModule.FileName;//可获得当前执行的exe的文件名. string st ...
- Google android开发者 中国官方文档开放了呀
Google官方开发文档地址 包括 android , android TV
- HashMap put、get方法源码分析
HashMap.java的实现是面试必问的问题. JDK版本 java version "1.8.0_91" Java(TM) SE Runtime Environment (bu ...
- 提交自己的包到 npm 中
npm npm全称Node Package Manager,是node.js的模块依赖管理工具.使用github管理NPM包的代码,并定期提交至NPM服务器:npm官网 提交自己开发的NPM包 创建p ...
- Android StickHeaderRecyclerView - 让recyclerview头部固定
介绍在项目中有时会需要recyclerview滑动式时某个view滑出后会固定在头部显示,比较常用的比如手机联系人界面.地区选择界面等. StickHeaderRecyclerView就是实现这个功能 ...
- html 表格单元格的宽度和高度的设置
做网页的时候,经常会碰到表格宽度对不齐的问题.详细地看了html中表格标签table的高度和宽度设置的细节,现总结如下: 1.table中的width和height设置及其作用:table中设置的he ...
- Windows7建立无线热点
很实用的技巧,加以记录. 最初我是想使用connectify的,不过安装这个软件之后,发现有线账号登不上了,所以就选择使用Windows7自带的工具了. 首先以管理员身份运行cmd. 进入之后cd到c ...
- Android之Fragment 基本介绍(转)
Fragment Android是在Android 3.0 (API level 11)开始引入Fragment的. 可以把Fragment想成Activity中的模块,这个模块有自己的布局,有自己的 ...