Entity Framework 框架
微软官方提供的ORM技术的实现就是EF(Entity Framework)框架。EF的模式有三种分别是:Database First 数据库先行 ,Model First 模型先行 , Code First 代码先行 , 最后介绍的就是POCO 它的全称:Plain Old CLR Object,简单传统的公共语言运行时对象。
这里简单介绍一下 Code First 模式:Code First是指“代码优先”或“代码先行”。这种方式在上下文设计模式中非常有用。使用Code First模式,可以专注于数据上下文的设计,根据需要,为一个数据上下文的对象创建类集合,而不是首先来设计数据库,然后来根据数据库设计实体类,Code-First 模式将会基于编写的类和配置,自动创建模型和数据库。
Code First模式的核心是,我们只需要编写代码,来自动创建数据模型和数据库,模型和数据库直接通过C#类来定义,而并不使用基于XML的edmx文件。如果采用Database First模式生成代码,需要使用EF设计器辅助工具,而使用Code First可以直接通过使用最简单的类来定义模型。
三种模式如图:

ORM的全称为“对象关系映射”(Object Relational Mapping)。ORM是随着面向对象的软件开发方法发展而产生的。用来把对象模型表示的对象映射到基于SQL的关系模型数据库结构中去。这样,我们在具体的操作实体对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作实体对象的属性和方法。ORM技术是在对象和关系之间搭建了一条桥梁,前台的对象型数据和数据库中的关系型的数据通过这个桥梁来相互转化。
ORM方法论基于的三个核心原则:
1.简单:以最基本的形式建模数据。
2.传达性:数据库结构被任何人都能理解的语言文档化。
3.精确性:基于数据模型创建正确标准化的结构。
ORM技术简单示意图

ORM的优点:ORM通过关系数据和对象之间的映射,自动生成SQL语句,将程序员从繁琐的数据库操作代码中解脱出来,将精力放在对具体业务逻辑上。只需编写一次代码,做较少的修改,就能适应其他类型的数据库。
由于ORM技术在极大程度上提升了开发效率,因此众多厂商和开源社区都提供了对ORM的实现。微软官方提供的ORM技术的实现就是EF(Entity Framework)框架。这套框架是基于ADO.NET的ORM框架。
EF框架的主要特点:支持多种数据源,支持存储过程的映射,提供Visual Studio集成工具,执行可视化操作。
1.这套框架是基于ADO.NET的ORM框架。
2.ORM用来把对象模型表示的对象映射到基于SQL的关系模型数据库结构中去。
3.ORM技术是在对象和关系之间提供了一条桥梁,前台的对象型数据和数据库中的关系型的数据通过这个桥梁来相互转化。
4.ORM方法论基于三个核心原则。
简单:以最基本的形式建模数据。
传达性:数据库结构被任何人都能理解的语言文档化。
精确性:基于数据模型创建正确标准化的结构。
5.ORM的具体含义是:O对应程序中的实体类;R对应数据库中的关系表;M表示程序中的对象和数据库中关系表数据的映射关系。
最后就是EF框架支持“Database First”、“Model First”和“Code First”三种方式来完成数据建模。Database First模式称为“数据库优先”或“数据库先行”模式,即先创建数据库,后生成数据模型。在这种模式下,要求数据库已经创建完成并可以正常使用,然后使用Visual Studio中的EF模型设计器,根据已有的数据库生成数据模型。
Entity Framework 框架的更多相关文章
- Entity Framework框架 (一)
1. Entity Framework的详细介绍: Entity Framework简称EF,与Asp.net关系与Ado.net关系. Entity Framework是ado.net中的一组支持开 ...
- 深入了解Entity Framework框架及访问数据的几种方式
一.前言 1.Entity Framework概要 Entity Framework是微软以ADO.NET为基础所发展出来的对象关系映射(O/R Mapping)解决方案.该框架曾经为.NET Fra ...
- Entity Framework框架 (二)
一.前面一篇EF的介绍主要是通过linq语句,本篇主要是介绍一下不通过linq语句如何去操作EF执行查询sql语句与执行存储过程. 1. 其中的Acccout是输出参数对应的类.比如输出参数有三个值 ...
- Entity Framework 实体框架的形成之旅--数据传输模型DTO和实体模型Entity的分离与联合
在使用Entity Framework 实体框架的时候,我们大多数时候操作的都是实体模型Entity,这个和数据库操作上下文结合,可以利用LINQ等各种方便手段,实现起来非常方便,一切看起来很美好.但 ...
- Entity Framework实体框架使用TrackerEnabledDbContext进行操作日志跟踪
在EF实体框架中进行日志跟踪,一般都是自己写个Log实体类,在数据保存时进行属性原始值验证来进行日志跟踪.当然还可以使用一些第三扩展库例如:entity framework extended进行日志记 ...
- 开发 ASP.NET vNext 续篇:云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之后, 关于云优化和版本控制: 我本想做一下MAC和LINUX的self-ho ...
- 分享关于Entity Framework 进行CRUD操作实验的结果
我们在使用Entity Framework框架进行CRUD时,经常会出现各种各样的错误,下面请看我的实验结果. 以下是只用一个上下文对象进行操作: 第一次: BlogDbContext blog = ...
- Entity Framework 之三层架构
今天,我们谈一下如何用Entity Framework构建一个三层架构.即包括DAL层,BLL层和MODEL层.我们先看一下目录结构,如下图: 目录中,我们有Web层,AVON.DMS.Model是实 ...
- Entity Framework基金会
概要 Entity Framework缩写EF,微软ORM产品. 本篇博客将简单的介绍它,至于它的详细深层次的使用,大家能够查询对应的操作手冊,该篇不过入门. Entity Framework和Lin ...
随机推荐
- CSS-单位em 和 rem
1,em单位(css3新增单位) em:就是一种长度单位,它是参照当前元素的字号,如果没有设置,就参照父容器,一直到浏览器的默认字号大小 em 是相对长度单位(参照父元素),其参照当前元素字号大小,如 ...
- Vue 过滤器的使用
Vue官方文档是这样说的:Vue过滤器用于格式化一些常见的文本. 在实际项目中的使用: 定义过滤器 在src定义一个filter.js文件,里面定义过滤器函数,在最后要使用 exprot defaul ...
- tp5生成6位不重复验证码
/** * 获取激活码 */ public function getnum() { $time = Db::name('fangchan_jihuoma')->group('id desc')- ...
- C# 使用NPOI 处理Excel(Datable与Excel相互转换)
VS上有自带的程序集可以读取,但是总是会出现这样或那样的问题,让人恨得牙疼!而且效率太慢了.用NPOI就好多了,比较快,而且稳定,还简单,引用相应的程序集就好了. Excel转换成Datable pr ...
- 解决 Visual Studio 点击添加引用无反应的问题
如遇到vs2010 点击添加引用无反应,主要是因为windows系统推送的更新问题,把windows系统推送的更新都更新一遍就好了. 如果已经安装VS后 Windows系统推荐的更新.360推荐的安全 ...
- tag cloud的相关资料
http://reverland.org/python/2013/01/28/visualize-your-shell-history/ https://github.com/reverland/sc ...
- AI应用开发实战
AI应用开发实战 出发点 目前,人工智能在语音.文字.图像的识别与解析领域带来了跨越式的发展,各种框架.算法如雨后春笋一般,互联网上随处可见与机器学习有关的学习资源,各大mooc平台.博客.公开课都推 ...
- Centos7-驱动小米WIFI做AP
参考文章: http://blog.csdn.net/sumang_87/article/details/38168877 http://blog.csdn.net/hktkfly6/article/ ...
- SDL 开发实战(七): 使用 SDL 实现 PCM播放器
在上文,我们做了YUV播放器,这样我们就入门了SDL播放视频.下面我们来做一个PCM播放,即使用SDL播放PCM数据. 下面说明一下使用SDL播放PCM音频的基本流程,主要分为两大部分:初始化SDL. ...
- [Swift]LeetCode189. 旋转数组 | Rotate Array
Given an array, rotate the array to the right by k steps, where k is non-negative. Example 1: Input: ...