天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

走進Linq-Linq to SQL感性認識篇

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

不能不說的C#特性-對象集合初始化器

不能不說的C#特性-匿名類型與隱式類型局部變量

不能不說的C#特性-擴展方法

不能不說的C#特性-匿名方法和Lambda表達式

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

不能不說的C#特性-迭代器(下),yield以及流的延遲計算

走進Linq-Linq to Objects(上)基礎篇

走進Linq-Linq to Objects(下)實例篇

走進Linq-Linq to SQL感性認識篇

走進Linq-Linq to SQL How do I(1)

走進Linq-Linq to SQL How do I(2)

走進Linq-Linq to SQL How do I(3)

走進Linq-How do I(4)拾遺補零篇第一節

走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

走進Linq-Linq to SQL源代碼賞析之Provider的初始化

走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq


很多人一提到Linq就提到操作數據庫什么的,其實操作數據庫的只是Linq中的Linq to SQLLinq本身是一個很大的家族,而且Linq家族極具擴展性。從人們一提到Linq就把她當作一個ORM這個來看,說明廣大程序員對Linq to SQL期望值很高,高過其他幾種,對微軟在框架中集成ORM的期望值也很高。從今兒起我將用幾篇來介紹Linq to SQL

Linq to SQL的核心庫是System.Data.Linq.dll(位于C:"Program Files"Reference Assemblies"Microsoft"Framework"v3.5目錄下),不過,System.Core.dll里的System.Linq是整個Linq的核心。在System.Data.Linq.dllSystem.Data.Linq命名空間下的DataContext類是Linq to SQL的入口點,可以說Linq to SQL一切奇妙之處都來源如此。通過DataContxt我們可以獲取Table對象(這個類和DataContext在同一命名空間下),你會發現Table竟然是繼承自IEnumerable,那上一篇介紹的那些查詢表達式都可以應用Table對象上了,呵呵。

有過使用ORM框架的讀者肯定知道,一般ORM框架都有個映射,就是將內存中的對象和數據庫表做映射,大名鼎鼎的NHibernate是使用XML文件做映射的(我們一般將這種映射稱之為無入侵的),還有ActiveRecord模式一般式在屬性上加Attribute做映射的(一般稱之為侵入式的)Linq to SQL也不例外,也需要一個映射,她使用的是侵入式的,所以就需要一些Attribute,這些Attribute放在System.Data.Linq.Mapping命名空間下。

作為微軟大張旗鼓推出的ORMLinq to SQL目前卻支持Sql Server,這個未免有些遺憾(所幸的是對于其他幾種數據庫已經有開源實現了),不過放心,看看核心庫里面的命名空間你也許看到了曙光。在System.Data.Linq.dll還有兩個命名空間:

System.Data.Linq.Provider,這個命名空間是提供一些Provider模式的接口,由于不同數據庫所需要的SQL語句,一些函數都有一些不同,但是她們的操作卻都大同小異,所以我們可以抽象一個統一的接口,然后有各個數據庫的實現(非常奇怪微軟為啥將IProvider接口設置為internal的,難道他只想他自己一個人干?)System.Data.Linq.SqlClient命名空間里放的就是針對Sql Server的實現了,按照這個結構,支持所有的數據庫都是可以的。

好了,上面對Linq to SQL的一些組件做了一個大致的介紹,下面就稍微演示一段代碼。

要做一個Linq to SQLcase,首先你必須創建一個映射類,該類映射到數據庫表。實際上映射類和我們在上一篇所使用的實體類非常相似(確保對System.Data.Linq.dll的引用,并且對System.Data.Linq.Mapping命名空間的聲明)

[Table(Name="Users")]
    
public class User
    {
        [Column(IsPrimaryKey
=true)]
        
public int UserId { getset; }
        [Column]
        
public string UserName { getset; }
        [Column]
        
public string Password { getset; }
        [Column]
        
public string BlogName { getset; }
        [Column]
        
public Role Role { getset; }
    }

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

不能不說的C#特性-對象集合初始化器

不能不說的C#特性-匿名類型與隱式類型局部變量

不能不說的C#特性-擴展方法

不能不說的C#特性-匿名方法和Lambda表達式

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

不能不說的C#特性-迭代器(下),yield以及流的延遲計算

走進Linq-Linq to Objects(上)基礎篇

走進Linq-Linq to Objects(下)實例篇

走進Linq-Linq to SQL感性認識篇

走進Linq-Linq to SQL How do I(1)

走進Linq-Linq to SQL How do I(2)

走進Linq-Linq to SQL How do I(3)

走進Linq-How do I(4)拾遺補零篇第一節

走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

走進Linq-Linq to SQL源代碼賞析之Provider的初始化

走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq


(看到這里你也許會命名什么叫入侵式了吧,入侵式就是為了達到目的,對代碼做了一些改變,比如這里的Table,Column

User類上面加的Table表示這個類和一個表映射,表名為Users,注意,如果表名和類名是一樣的,這個Name屬性是無需指定的,在屬性或共有字段上加Column表示這個屬性和數據庫表里的字段映射,如果屬性名和數據庫表字段名一直只需要加個Column就夠了,如果這個屬性在數據庫表里是個主鍵,那么將其IsPrimaryKey設置為true就可以了。

映射建好了,該是Linq上場的時候了(我們要從數據庫表里查詢出用戶名以”yu”開頭的所有用戶)

//我們給定一個數據庫連接字符串實例化一個DataContext對象
DataContext dbContext = new DataContext(connectionString);

dbContext.Log 
= Console.Out;
//調用DataContext的GetTable方法,獲取一個Table對象
Table<User> users = dbContext.GetTable<User>();
//由于Table繼承自IEnumerable,所以,前面所介紹的那些查詢表達式在這里也使用了
var result = from user in users
           
where user.UserName.StartsWith("yu")
           select user;

//遍歷結果集
foreach (var u in result)
    Console.WriteLine(u.UserName);

it知識庫走進Linq-Linq to SQL感性認識篇,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 激情内射亚洲一区二区三区 | 日本久久精品毛片一区随边看 | 99精品影院 | 老师机影院 | 被室友C哭调教双性 | GAY2022空少被体育生暴菊 | 国产综合欧美区在线 | 久久re这里视频精品15 | 日韩精品无码视频一区二区蜜桃 | 桃花免费高清在线观看 | 永久午夜福利视频一区在线观看 | 2021扫黑风暴在线观看免费完整版 | 久久黄色免费 | 久久草福利自拍视频在线观看 | 亚洲 视频 在线 国产 精品 | 富婆夜店找黑人猛男BD在线 | 亚洲无吗在线视频 | 99视频免费在线观看 | 午夜福到在线2019 | 欧美阿v在线免播播放 | 在线中文字幕亚洲日韩 | 乳欲性高清在线 | 老师小扫货水能么多叫出来 | 看美女大腿中间的部分 | www.精品视频 | 小sao货ji巴cao死你视频 | 久久机热视频免费 | 国产午夜久久影院 | 99在线在线视频观看 | 精品国产国产精2020久久日 | 精品久久久噜噜噜久久7 | 国产色精品久久人妻无码看片软件 | xxx军人3p大gay | 羞羞麻豆国产精品1区2区3区 | 99这里有精品视频视频 | 国产人成高清在线视频99 | 冠希和阿娇13分钟在线视频 | 国产亚洲精品a在线观看app | 国产精品第3页 | 单亲妈妈3韩国电影免费观看 | 欧式午夜理伦三级在线观看 |