Entity Framework 与 LINQ to SQL
Entity Framework和LINQ to SQL到底有什么区别?这是一个很常见的问题。下面的表中简要罗列了两种技术的主要区别。
LINQ to SQL |
Entity Framework |
|
复杂度 |
相对不复杂 |
相对比较复杂 |
模型 |
域模型(Domain model) |
概念数据模型(Conceptual data model) |
数据库服务器 |
SQL Server |
多种数据库产品 |
开发时间 |
快速应用开发 |
需要较长时间,但支持更多特性 |
继承 |
困难 |
容易 |
文件类型 |
DBML文件 |
EDMX,CDSL,MSL,SSDL文件 |
复杂类型支持 |
不支持 |
支持 |
查询能力 |
通过DataContext |
ESQL,对象服务, Entity Client |
性能 |
第一次查询较慢 |
第一次查询也较慢,但总体优与LINQ to SQL |
完善 |
不再出新版本 |
还出新版本 |
从模型生成数据库 |
不支持 |
支持 |
复杂度:支持越多的特性就会越复杂。LINQ to SQL所支持的特性比较少,所以也就相对不太复杂;而EntityFramework支持的特性比较多,所以相对比较复杂。
模型:LINQ to SQL在数据表与类之间提供了一对一的映射。如果你有Customers,Orders, 和Lineitems表,你就会有Customer,Order, 和Lineitem类来匹配每一个表。EntityFramework可以使你有一个Customer类,而这个类可以匹配多个表。这就意味着公司名可以 在一个表中,但是地址是在另一个表中,而电话号码又在另一个表中,等等。
数据库服务器:LINQ to SQL只支持Microsoft SQL Server 2000及之后的版本,但即使是SQLServer2000也有很多限制。EntityFramework可以支持IBMDB2, Sybase SqlAnywhere, Oracle, SQLAzure,还有其他很多。
开发时间:LINQ to SQL很容易学,开发起来也很快,但是LINQ to SQL有一些限制,在开发较复杂的应用时可能会产生问题。EntityFramework的能力更强,虽然学习及应用起来比较慢,但是对更多的特性的支持使得在开发较复杂的应用时可以使问题最小化。
继承:LINQ to SQL支持TPH,而EntityFramework支持TPH和TPT,并且对TPC也部分支持。
文件类型:LINQ to SQL使用包含XML的数据库标记语言(DBML)文件来映射entity与数据表。EntityFramework 使用四个文件。第一个是Entity Data Model (EDMX),这个是在设计器中使用的。在编译时EDMX文件产生了其他三个文件。另外三个文件中,第一个是ConceptualSchema Definition Language(CSDL)文件,其包含概念模型的XML定义。第二个是SchemaDefinition Language(SSDL)文件,其包含存储模型的定义。第三个文件是Mapping Specification Language(MSL)文件,其包含概念模型与存储模型之间的映射。
复杂类型支持:比如说,一个客户有电话号码,但你想要电话号码定义为国家区号,地区号,城市区号,号码和分机号。LINQto SQL不支持这种复杂类型,而EntityFramework支持。
查询能力:LINQ to SQL通过DataContext对数据库进行查询。EntityFramework通过ObjectContext通过LINQto Entities进行查询。Entity Framework还提供了ESQL,它是一种类似SQL的查询语言,很适合在模型定义中定义查询。EntityFramework还包含了 ObjectQuery类,用于对象服务在运行时动态创建查询。最后EntityFramework还包含EntityClientProvider,它 用于对概念模型进行查询。
性能:LINQ to SQL和Entity Framework第一次执行查询的时候都比较慢,但之后性能都让人比较满意。EntityFramework性能要稍微优于LINQto SQL。
完善:微软在发布了Entity Framework之后就停止了发布新的LINQ to SQL,但由于LINQto SQL的简单性,它还是很受欢迎的,所以微软仍将继续对LINQto SQL的用户进行支持与反馈,但是LINQto SQL将不再发布新版本进行完善。
由模型生成数据库:LINQ to SQL没有能力由模型生成数据库。Entity Framework支持两种类型的开发模式,数据库优先和编码优先。数据库优先开发,数据库已经存在,所以不需要由模型生成数据库。编码优先,你要先创建你的模型,然后由模型生成数据库。
转载于:https://www.cnblogs.com/tianguook/p/3942390.html
Entity Framework 与 LINQ to SQL相关推荐
- Entity Framework (EF)/Linq To entity/ ESQL(entity sql)区别 ADO.NET Entity Framework:来自微软官方的ORM框架
长久以来,程序员和数据库总是保持着一种微妙的关系,在商用应用程序中,数据库一定是不可或缺的元件,这让程序员一定要为了连接与访问数据库而去学习 SQL 指令,至少对于我而言,我觉得这是一个很不爽的事情. ...
- Entity Framework查询,EF执行SQl
一.简介 EF 支持开放底层的 ADO.NET 框架,DbContext有三种常用方法 DbSet.SqlQuery //查询并返回Entities DbContext.Database.SqlQue ...
- C#综合揭秘——Entity Framework 并发处理详解
引言 在软件开发过程中,并发控制是确保及时纠正由并发操作导致的错误的一种机制.从 ADO.NET 到 LINQ to SQL 再到如今的 ADO.NET Entity Framework,.NET 都 ...
- Entity Framework Core 执行SQL语句和存储过程
无论ORM有多么强大,总会出现一些特殊的情况,它无法满足我们的要求.在这篇文章中,我们介绍几种执行SQL的方法. 表结构 在具体内容开始之前,我们先简单说明一下要使用的表结构. public clas ...
- 【查询】—Entity Framework实例详解
Entity Framework 查询使用集成查询,简称LINQ.LINQ是一个查询框架,并不限于Entity Framework使用,同样不限于数据库.LINQ Provider 负责将LINQ查询 ...
- 软件开发知识--[ADO.NET Entity Framework]
ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案,早期被称为 ObjectSpace,现已经包含在 Vi ...
- 在.NET 3.5 平台上使用LINQ to SQL创建三层/多层Web应用系统 (Part 1)
在.NET 3.5 平台上使用LINQ to SQL创建三层/多层Web应用系统 (Part 1) 在新的.Net Framework 3.5平台上,Microsoft发布了LINQ(C# 3.0, ...
- 在.NET 3.5 平台上使用LINQ to SQL创建三层/多层Web应用系统(Part5) 转
设计开发表现层 表现层负责应用程序的用户界面,图4.1是表现层的详细视图,包括Web Forms, Web User Control, Code-Behind 和共享的用户界面代码.表现层负责推送信息 ...
- 在.NET 3.5 平台上使用LINQ to SQL创建三层/多层Web应用系统(Part2) 转
LINQ to SQL LINQ to SQL 提供了访问数据库的方法,且允许我们做所有数据库相关的操作,如查询.插入.更新和删除.LINQ to SQL消除了写存储过程和从数据访问层调用的过程,它可 ...
最新文章
- 列表组件之ListView
- 基于墨刀的软件界面原型设计——小说搜索阅读软件
- Iphone表视图的简单操作
- matlab立体坐标定位_【半导光电】基于光电探测器的激光章动定位算法(二)
- mysql hash分区 创建_如何建mysql hash数据库分区
- erp代码matlab,ERP1 Protocol in Matlab - 源码下载|Windows编程|其他小程序|源代码 - 源码中国...
- BZOJ 1051 || POJ 2186 受欢迎的牛 Tarjan
- memcache的资料集
- 18.10 汇编语句
- KEPServerEX V6轻松连接Wonderware InTouch
- c语言海报设计图片,ps海报设计教程:一张照片配文字排版技巧
- java查询城市区号_中国城市电话区号对照表
- 大学心理学课本_大学心理学的教材依次(全部)都有哪些?
- Lua 颜色值转换 -- Color
- 刘强东:大学打过好几份工 最赚钱的是编程
- 2022中国MarTech领域最具商业合作价值企业盘点
- 前端案例:像素鸟小游戏(js+dom操作,完整代码,附案例素材)
- 深入Python进程间通信原理
- 《数据库系统概念》第一章:引言
- 数据爬取——拍信网美女图片
热门文章
- 库洛游戏首次公开分享:《战双帕弥什》的动作打击感是怎么做出来的
- 浅谈RTS游戏网络同步:3种同步机制模式的实现
- 剑与远征英雄兑换码如此少见,新玩家连抽获得数位英雄
- 利用dbms_metadata.get_ddl查看DDL语句(原创)
- java学习之单例模式(饿汉式与懒汉式)
- 图解CSS3----5-否定伪类选择器
- 写给大家的编程书(2)
- python写网络调试助手_Qt开源作品4-网络调试助手
- typescript语法高亮插件_JavaScript开发者必备的10个Sublime Text插件
- Java黑皮书课后题第2章:*2.17(科学:风寒温度)外面有多冷?...twc=35.74+0.6215ta-35.75v0.16+0.4275tav0.16,输入度数、风速显示风寒温度