自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

LINQ ORM詳細比較

開發(fā) 后端
這里介紹LINQ ORM都是一種技術概念,LINQ是一種語言特性,在語言(Language)中集成(Integrate)查詢(Query)句法,ORM是Object/Relation Mapping。

LINQ有很多值得學習的地方,這里我們主要介紹LINQ ORM之間的關系,包括介紹LINQ to SQL是.NET 3.5內(nèi)置的一個輕量級O/R Mapping解決方案等方面。

1.LINQ不是ORM,確切地來說,他們之間的關系是:

LINQ的一個子集是屬于ORM的

2.他們之間的唯一的相同點是:

LINQ ORM都是一種技術概念,而不是一種實現(xiàn),最大的區(qū)別就在于——他們根本就不是一路東西!

LINQ是一種語言特性,在語言(Language)中集成(Integrate)查詢(Query)句法,所以才叫LINQ——Language-Integrated Query,目的是以一種看起來像SQL的方式來完成原本你需要去foreach的工作——最顯著的就是集合操作,比如搜索啊,排序啊,批量更新啊。因為 SQL是為關系數(shù)據(jù)庫而存在的,關系數(shù)據(jù)理論是建立在集合論的基礎上的,所以集合操作當然是最本職的工作啦!

ORM是Object/Relation Mapping。Object是哪路?是Object Oriented Programming那路Object,Relation是哪路?是關系數(shù)據(jù)理論那路Relation,ORM的作用是在對象和關系之間建立映射,讓開發(fā)者可以以面向?qū)ο蟮姆绞饺ネ瓿梢恍╆P系數(shù)據(jù)操作——這些原本需要用關系代數(shù)、關系操作語言,這些通??雌饋碛悬c生硬,還得花心思去專門學的東西來解決的操作。

LINQ ORM就不是一路上的東西,但是為什么很多人會把他們扯在一起呢?

3.有兩個最主要的原因

第一:LINQ長得太像SQL了!SQL是關系數(shù)據(jù)訪問領域目前階段當之無愧的帶頭大哥,ORM是一個挺時髦的關系數(shù)據(jù)訪問面向?qū)ο蠡鉀Q方案,也和SQL離不開關系,兩者就靠SQL搭上邊了。

第二:LINQ to SQL的存在。LINQ to SQL是一個ORM框架,它利用了LINQ的便捷性和LINQ長得像SQL這個特點,實現(xiàn)了一個用LINQ來完成關系型數(shù)據(jù)庫(這里是SQL SERVER)數(shù)據(jù)訪問的便捷通道。

4.LINQ / LINQ to SQL / LINQ to XXX

LINQ是新生事物,不過從不少文章和討論上看來,這方面的概念也已經(jīng)有點混沌不清了。因此我們經(jīng)??梢钥吹竭@樣的話:

◆LINQ只能將數(shù)據(jù)表與實體屬性一一對應……
◆LINQ開發(fā)指南:在LINQ中進行數(shù)據(jù)庫字段映射……

以上兩句話其實說的都是LINQ to SQL而不是指LINQ??赡苡捎贚INQ to SQL的上鏡率最廣(連MSDN上About LINQ的第一個示例就是查詢數(shù)據(jù)庫的),因此許多人都將LINQ to SQL與LINQ混用,這會給初學者造成誤解,認為LINQ就是LINQ to SQL,LINQ to SQL就是LINQ——事實當然不是這樣的。

LINQ是Language-Integrated Query的縮寫,是C# 3.0和VB 9.0中新加入的語言特性,可以在編程時使用內(nèi)置的查詢語言進行基于集合的操作。這么做可以大大簡化開發(fā)過程,提高開發(fā)效率。例如:

  1. List userList = GetUserList();  
  2. var userWithOddId = from u in userList  where u.UserID % 2 == 1  select u;   
  3. foreach (User u in userWithOddId)  {  
  4. Console.WriteLine(u.UserName);  
  5. }   

如果沒有LINQ,要篩選出ID為奇數(shù)的User對象則需要創(chuàng)建一個List,然后遍歷整個列表,將符合特定條件的User對象放入新列表。而有了 LINQ,這部分的篩選就變得非常容易,甚至只需要一句話就能完成。如果覺得這個例子不夠說明LINQ對生產(chǎn)力有重大貢獻的話,請關注我接下來的一篇文章(暫定名為《我們?yōu)槭裁匆獡肀INQ》)。LINQ特指形如上面這段代碼中from...where...select這樣的用法,其返回值是 IQueryable。

LINQ to SQL是.NET 3.5內(nèi)置的一個輕量級O/R Mapping解決方案,可以將數(shù)據(jù)表映射為實體對象,方便開發(fā)人員對數(shù)據(jù)庫的操作??梢?,LINQ to SQL實只是LINQ的一個實現(xiàn),提供了一個可以查詢SQL Server數(shù)據(jù)庫的LINQ Provider。

LINQ Provider是LINQ 查詢的執(zhí)行器,標準LINQ語法支持許多的操作符,但是某個具體的LINQ實現(xiàn)可能只支持其中的一部分。在.NET 3.5默認提供了三種LINQ Provider,分別是LINQ to Object(即上面的例子),LINQ to SQL以及LINQ to XML。

LINQ to XXX表示使用LINQ針對XXX這種數(shù)據(jù)進行查詢的解決方案。我們可以自定義LINQ Provider,使用我們自定義的查詢規(guī)則來處理特定數(shù)據(jù)集。目前互聯(lián)網(wǎng)上已經(jīng)可以找到數(shù)十種LINQ Provider(如LINQ to Flickr,LINQ to NHibernate等),而已經(jīng)處于beta 3階段的ADO.NET Entity Framework,最終也會提供一個LINQ Provider,叫做“LINQ to Entities”。以上介紹LINQ ORM。

【編輯推薦】

  1. LINQ查詢操作剖析
  2. LINQ生成字符串概述
  3. LINQ查詢語法簡單描述
  4. LINQ解決方案簡單概述
  5. LINQ查詢結(jié)果分析
責任編輯:佚名 來源: IT168
相關推薦

2009-09-14 17:40:47

LINQ To SQL

2009-09-18 09:25:06

LINQ Framew

2009-09-14 15:15:45

LINQ技術

2009-09-15 13:59:18

LINQ to Dat

2009-09-08 13:07:15

介紹Linq to S

2009-09-15 13:20:34

LINQ DataCo

2009-09-14 13:14:49

LINQ序列

2009-09-14 14:58:52

LINQ to XML

2009-09-17 13:10:48

linq動態(tài)排序

2009-09-14 16:33:55

LINQ To XML

2009-09-14 14:17:11

Linq異常處理

2009-07-29 08:58:20

NHibernate ORM框架

2009-12-15 18:39:36

Ruby Active

2009-09-09 09:48:43

Linq延遲加載

2009-09-08 11:09:39

LINQ數(shù)據(jù)源

2009-09-14 16:21:34

LINQ To XML

2009-09-14 13:50:35

LINQ編程模型

2009-09-08 15:56:50

Linq使用Group

2009-09-17 10:40:22

Linq Lambda

2009-06-26 15:17:44

SDOEJB 3.0
點贊
收藏

51CTO技術棧公眾號