Model First:创建实体数据模型(ADO.NET 实体数据模型)
Microsoft Entity Framework是一个对象关系映射工具(Object Relational Mapping ,O/RM)工具。它可以让你从一个数据库自动地生成数据接入层。实体框架免去了你手工创建数据接入层的乏味工作。ADO.NET 实体数据模型可以映射数据库与数据表,也可以映射模型类。它是关系数据库与面向对象系统的桥梁,闲话少说,就让我们举个简单的例子来解析它吧!
Model First方式创建数据库
1.启动VS2010.创建一个Console application(控制台) : 名为:EFModelDemo 如下图:

2. 在项目上,右键=》选择“添加->新项目..” 如下图:选择:Ado.net entity data model : 名为:School

3. 选择“empty model ” 点击完成 .如下图:

4. 此时会自动打开edmx的设计器界面;如下图:

5. 用鼠标拖动“entity(实体) ”到界面设计器上。就会生成一个实体出来。如下图:

如果你想重命名一个实体类,你可以双击实体设计器里的类的名字然后输入一个新的名字。或者,你可以在实体设计器里选择一个实体后在属性窗口里修改这个实体的名字。记住在修改后保存你的实体数据模型。在这个场景后面,实体设计器生成了一系列的C#模型类。你可以在解决方案浏览器窗口里通过打开XXModel.Designer.cs文件看到这些类。别修改Designer.cs里面的代码,因为你的改动会在下一次使用实体设计器的时候会被重新覆写。
如果你只想要扩展在Designer.cs里面的实体类的功能,你可以在单独文件里创建部分类。
6. 给这三个实体增加其它属性:在设计器上点击鼠标右键来添加。默认情况下:属性是string类型的。选中实体中的某一个属性项(如ClassID),然后在属性面板中将其type改为:int32.(因为,它将作为外键与Couse实体中的ID对应,所以确保两者的类型要一样)如下图:

7. 建立关联:在toolbox中,用鼠标左键单击一下“关系”,然后可以松开鼠标,“关系 ”仍处于选择状态。移动鼠标到设计面板上,当鼠标靠近实体时,鼠标指针会变化成折线。在主实体上按下左键,并拖动到从实体上,松开左键,此时会有一根线产生。就是关联。如下图:

8. 修改Student , Course 之间的关联为多对多(就*代表多个。*对*)。如下图:

9. 双击class,student之间的关联,设置如下图:

10. 在Model First 中,EF不会为我们创建数据库只会创建表。所以我们要事先用SQL server 2012建立空数据库:

在edmx设计器上空白地方,右键:“根据模型生成数据库”,进入“生成数据库”向导,建立数据库连接。


当连接服务器成功以后,点击:执行脚本。则会在数据库school中生成相应的数据表。

注意:观察生成的数据表:student,course之间是多对多关系,所以会生成一个中间表:studentcourse,主键就是由student,course的主键组合.在student 表中,我们设计了一个ClassID用于外键关联class实体。这种关联在EF中称作:外键关联(有专门的一个外键去和导航属性对应)。EF还支持另外一种关联:独立关联(没有专门的一个外键去和导航属性对应,EF在没我外键的情况下,也可以跟踪管理导航属性)。这里我们按在没有ORM框架的时候,我们采用的传统做法:就是采用外键关联两个实体。
另外,ADO.NET 实体数据模型向导还可以直接使用从现有数据库创建模型,这种方式(Database First)比较简单在此就不提了,根据向导指示就可以了。
Model First:创建实体数据模型(ADO.NET 实体数据模型)的更多相关文章
- 《MVC+EF》——用DBFirst创建ADO.NET实体数据模型和对象关系映射
转载于:http://blog.csdn.net/zhoukun1008/article/details/50528145 现在越来越喜欢MVC了,不光是因为ITOO中用到了他,而是因为它里面包含了很 ...
- Visual 2015创建新项,缺少ADO.NET 实体数据模型的解决方法
现在的某度查资料真的很麻烦,突然我自身的VS2015创建EF的时候找不到 ADO.NET 实体数据模型,但是使用CodeFrist是可以生成数据表的.所有特别郁闷. 打开界面如下 某度半天,都没有查出 ...
- vs212创建mvc3项目,添加ADO.NET实体数据模型时产生 XXXX.Desiger.cs 文件为空
vs212创建mvc3项目,发现添加ADO.NET实体数据模型时,产生StoreDB.Desiger.cs文件为空 产生StoreDB.Desiger.cs文件为空 原因是,在vs2012中,添加AD ...
- Visual Studio2017中如何让Entity Framework工具【ADO.NET实体数据模型】支持MYSQL数据源
熟悉Entity Framework应该对以下图片不陌生,他就是ADO.NET实体数据模型向导:可以将数据库的表自动生成模型类,或者创建Code First的模型文件. 但是这个模型向导默认只显示微软 ...
- ADO.NET实体数据模型使用探索1
今天研究了下ADO.NET实体数据模型,想写个关于两张有外键关系的增改删查,以此来稍增加点难度. 编程环境:vs2010+sql2005 1.在SQL2005下建立三张表:学生信息表Student(S ...
- 连接SQLite 创建ADO.net实体类
0.开发环境 win10,vs2013-x64 1.安装: sqlite-netFx451-setup-bundle-x86-2013-1.0.102.0.exe 注意事项:选在VisualStudi ...
- ADO.NET实体数据模型中关于数据库字段默认值的处理
无论是Visual Studio 2010或者2013内置的ADO.NET实体数据模型都有一个小问题:数据库中有些字段已设置了默认值,但ADO.NET实体数据模型工具并不会自动进行设置. 这时需要手工 ...
- Visual Studio2017中如何让ADO.NET实体数据模型[EntityFramework]支持MariaDB&MySQL数据源
近期由于工作需要,需要重新修改设计系统的ADO.NET实体数据模型.edmx文件中间,在完成实际中途遇到一些实际使用问题,特此记录. 1. Visual Studio 2017 无法以实体设计模式打开 ...
- EFCore 通过实体Model生成创建SQL Server数据库表脚本
在我们的项目中经常采用Model First这种方式先来设计数据库Model,然后通过Migration来生成数据库表结构,有些时候我们需要动态通过实体Model来创建数据库的表结构,特别是在创建像临 ...
随机推荐
- 怎样衡量一个组员在团队中的Performance
My Attitude: 我认为评价一个团队的成员要看贡献,一切的Personal Ability, Attitude都要以这个为前提. Principal: 公平的原则+推动团队的发展 二者在大部分 ...
- HTML页面导出为Word
protected void btnExport_Click(object sender, EventArgs e) { string strFileName = DateTime.Now.ToStr ...
- 函数与关系实例,函数运算与SQL,试验与关系元组
函数是一个集合,它的每个元素都是二元组或多元组.例如 f = { (x, y) | x∈R & y∈R & y = 2x } ,g = { (x, y, z) | (x, y, z)∈ ...
- Oracle中将小数转换成字符丢零.截取小数.除数为零解决法
如下所示,前面少个0 SQL>select money from users where username ='LEI'; money --------- .3256 解决方法: SQL> ...
- 利用反射自动生成SQL语句(仿Linq)
转:http://www.cnblogs.com/the7stroke/archive/2012/04/22/2465597.html using System; using System.Colle ...
- SELECT样式,兼容IE6
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- lightoj 1021 (数位DP)
题意:给你一个b进制的数,再给你一个十进制数k,你可以重新排列b进制数的每一位得到其他b进制数,问你这些数中有多少可以整除k? 思路:数位dp. #include <cstdio> #in ...
- 【QTP】自动化测试:
一.参数化: 1.随机数: 下面两个语句都可以: Window("Flight Reservation").Dialog("Flights Table").Wi ...
- opencv行人检测里遇到的setSVMDetector()问题
参考了博客http://blog.csdn.net/carson2005/article/details/7841443 后,自己动手后发现了一些问题,博客里提到的一些问题没有解决 ,是关于为什么图像 ...
- 利用flashback query 恢复表数据
flashback query可以查询过去某个时间点对象的状态,从而可以利用此来进行恢复数据 1 准备测试数据 用普通用户创建一个表,表中插入部分数据: SQL> show user USER ...