序言<EntityFramework6.0>
Entity Framework是微软战略性的数据访问技术,不同与早期访问技术,Entity Framework并不耦合在Visual Studio中,它提供了一个全面的, 基于模型的生态系统,使您能够开发包括桌面、互联网、云计算和基于服务的应用程序等
历史

EFVersion1 支持Database Frist
EFVersion4 支持Database Frist+Model First【along with full Plain Old CLR Object (POCO) support and
default lazy loading behavior】
EFVersion4.1一EFVersion4.3 支持Database Frist+Model First+Code Frist
EFVersion5 改进性能,支持枚举,表值函数、空间类型, 存储过程【此时只限于Database Frist】,与MVC框架的进一步结合。
EFVersion6 提供了异步的查询和更新,在CodeFrist中开始支持存储过程,提升性能以及引入一些新特性。
模型

使用EntityFramework创建一个模型,最显著的特点就是创建一个实体数据模型(Entity Data Model【EDM】),使用EDM可以自定义实体类和数据表之间的映射关系
Developer:只需要着眼于领域对象模型的开发【即可以直观描述具体问题信息的类】
DBA:更多的从性能,扩展性,易维护性和高度规范性去设计数据库。
例如:上图中的Employees, Devices, Phone信息存在三个不同的物理数据表中,这是从DBA的角度考虑的,但是存developer角度设计的时候,他会在Employee类中包含Devices, Phone的集合信息,同样的,DBA将与部门相关的所有信息全部放在一张Depeartment表中,而developer根据开发的关注的问题需求,将其细分为(会计,市场营销,金融等具体实体对象)。也就是说从不同的角度看问题,developer不会去关心DBA怎么设计数据表,DBA也不会去关心developer怎么设计实体类。他们可能同处在一个项目组中,可行其职,最优化的设计自己的方案而互不影响充分的解耦,而交互的工作就由EntityFramework进行处理了。
层
Entity Data Model 由概念层,存储层,映射层构成,每一层都是相互独立的。
其中实体类是包含在概念层【conceptual layer】中,而这一层也是开发人员最关心的。也可以利用EntityFramework自带的工具进行反向工程,即从已存在的数据库创建实体类,其所用的语法为概念架构定义语言【CSDL】。
实体数据模型的存储层定义表,列,关系和数据类型如何映射到底层数据库。其所用的语法为存储架构定义语言(SSDL).
映射层定义的概念和存储层之间的映射。除此之外,这层定义了如何从实体类的属性映射到数据库表中的列。这个层被暴露给开发者,developer可以利用EntityFramework设计映射详细信息的窗口或者数据注解的方式以及如果使用Code Frist方式时可利用Fluent API进行定义,其所用的语法为映射规范语言(MSL)
术语

EntityType代表域模型中的一个类。EntityType的一个实例是通常被称为一个实体。如果您使用的是EntityFramework的设计器,可以看到如上图所示的表示。EntityType通常有一个或多个属性。属性可以是简单的类型,如整型,字符串,等等;或者复杂类型;或者是集合。导航属性用于关联其他相关实体(通常通过外键关系数据库中的表示)。非导航属性被称为标量属性。
两个实体之间的关系被称为关联。EntityTypes之间的关联显示在设计视图中是连接EntityTypes的一条线。
EntityType有一个属性或一组属性代表其的EntityKey属性。一个的EntityKey唯一标识该实体,它最常被映射到底层数据库的一个主键 。
context object 是获取EntityFramework服务的网关。管理数据库连接,生成参数化SQL,执行数据存取,缓存对象,跟踪和抽象数据转换为包含具体的参数类型的实体类。
DbContext 是对EntityFramework支持的ObjectContext的一种包装,因而更加直观,友好。

怎么编码
1.EF/VS借力于T4模板自动生成代码
2.使用CodeFrist的模式手动编写独立于EntityFramework管道的POCO类【也可借助Entity Framework Power Tool反向生成】。
序言<EntityFramework6.0>的更多相关文章
- 使用简介<EntityFramework6.0>
序言 在这一篇中,我们将演示EnitityFramework基本的建模[建模也是EntityFramework最核心的特性]范例,例如实体的分离和继承等.我们开始了演示如何创建一个简单的概念模型的例子 ...
- 分割一个表到多个实体<EntityFramework6.0>
声明方式 public class Photograph { [Key] [DatabaseGenerated(DatabaseGeneratedOption.Identity)] public in ...
- 继承映射关系 TPH、TPT、TPC<EntityFramework6.0>
每个类型一张表[TPT] 声明方式 public class Business { [Key] public int BusinessId { get; protected set; } public ...
- 将一个实体数据保存到不同的数据表中<EntityFramework6.0>
2014-11-22声明方式 public class Product { [Key] [DatabaseGenerated(DatabaseGeneratedOption.None)] public ...
- 自连接<EntityFramework6.0>
自引用 public class PictureCategory { [DatabaseGenerated(DatabaseGeneratedOption.Identity)] public int ...
- 多对多关系<EntityFramework6.0>
无负载建立多对多关联的模型 原文中是Modeling a Many-to-Many Relationship with No Payload,虽然这么翻译也有点不准确,但是可以说明其目的,如下图所示, ...
- EntityFramework6.0的Sql读写分离拦截器 和 MVC的 Action拦截器 对比
EF的DbCommandInterceptor类 拦截: EF6.1也出来不少日子了,6.1相比6.0有个很大的特点就是新增了System.Data.Entity.Infrastructure.Int ...
- 升级实体框架EntityFramework6.0
首先安装nuget 管理器 https://visualstudiogallery.msdn.microsoft.com/4ec1526c-4a8c-4a84-b702-b21a8f5293ca 安装 ...
- Nopcommerce 二次开发0
Nopcommerce 是国外的一个高质量的开源b2c网站系统,基于EntityFramework6.0和MVC5.0,使用Razor模板引擎,有很强的插件机制,包括支付配送功能都是通过插件来实现的 ...
随机推荐
- Struts2--属性设置方式
Struts2自动获取/设置数据的方式一共分为两种 属性驱动(FieldDriven) 模型驱动(ModelDriven) 属性驱动 属性又分为两种: |- 基本数据类型 |- JavaBean属性类 ...
- api接口类型
类型一:js+xml 类型二:纯php模式 参考: <?php $ip = '117.25.13.123'; $datatype = 'text'; $url = 'http://api.ip1 ...
- 关于tkCommand的各种事件的解释
superclass for callback/observer methods vtkCommand is an implementation of the observer/command des ...
- [从产品角度学EXCEL 03]-单元格的秘密
这是<从产品角度学EXCEL>系列——单元格的秘密. 前言请看: 0 为什么要关注EXCEL的本质 1 EXCEL是怎样运作的 2 EXCEL里的树形结构 或者你可以去微信公众号@尾巴说数 ...
- 前端应当了解的Web缓存知识
缓存优点 通常所说的Web缓存指的是可以自动保存常见http请求副本的http设备.对于前端开发者来说,浏览器充当了重要角色.除此外常见的还有各种各样的代理服务器也可以做缓存.当Web请求到达缓存时, ...
- Redhat6.4下安装Oracle10g
Oracle10g_Redhat6.4 安装指南 文档说明 本文借鉴<Redhat_Linux_6.4下Oracle_10g安装配置手册><Redhat 6.4 安装 Oracle1 ...
- Android Notification通知详解
根据activity的生命周期,在activity不显示时,会执行onStop函数(比如按下home键),所以你在onStop函数(按退出键除外)里面把notification放在通知栏里,再此显示时 ...
- 利用SQLite_Expert实现Excel表转SqLite数据库
1.保留excel数据中需要的字段,删除无关字段. 2.将excel另存为cvs格式文件.<另存名称如:jizhan.cvs 则导入后表名即为jizhan> 3.看下图,新建数据库,命名为 ...
- MySQL详解--锁
http://blog.csdn.net/xifeijian/article/details/20313977 2014-03-06 23:45 66484人阅读 评论(17) 收藏 举报 分类: ...
- 如何在Linux上使用文件作为内存交换区(Swap Area)
交换区域(Swap Area)有什么作用? 交换分区是操作系统在内存不足(或内存较低)时的一种补充.通俗的说,如果说内存是汽油,内存条就相当于油箱,交换区域则相当于备用油箱. Ubuntu Linux ...