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

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

系列文章導(dǎo)航:

走進(jìn)Linq--Linq橫空出世篇

走進(jìn)Linq-輝煌的背后

走進(jìn)Linq-Linq大觀園

不能不說(shuō)的C#特性-對(duì)象集合初始化器

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

不能不說(shuō)的C#特性-擴(kuò)展方法

不能不說(shuō)的C#特性-匿名方法和Lambda表達(dá)式

不能不說(shuō)的C#特性-迭代器(上)及一些研究過(guò)程中的副產(chǎn)品

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

走進(jìn)Linq-Linq to Objects(上)基礎(chǔ)篇

走進(jìn)Linq-Linq to Objects(下)實(shí)例篇

走進(jìn)Linq-Linq to SQL感性認(rèn)識(shí)篇

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

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

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

走進(jìn)Linq-How do I(4)拾遺補(bǔ)零篇第一節(jié)

走進(jìn)Linq-Linq to SQL源代碼賞析 Table的獲取過(guò)程

走進(jìn)Linq-Linq to SQL源代碼賞析之Provider的初始化

走進(jìn)Linq-Linq to SQL源代碼賞析,通過(guò)Linq to SQL看Linq


How Do I第一篇,難度系數(shù)50,定位為入門級(jí)。

上一篇對(duì)Linq to SQL做了一個(gè)大致的介紹,從這一篇起,將對(duì)要完成一項(xiàng)Linq to SQLCase要做的一些事情,主要從細(xì)節(jié)上做一些講解。不會(huì)很深入,但是卻又是必須的。為了使講解不落于泛泛而談,我們首先來(lái)構(gòu)建實(shí)例:

還是以博客園的系統(tǒng)為例子,既然稱Linq to SQL為一個(gè)ORM框架,ORM,對(duì)象-關(guān)系 映射,既然O在前關(guān)系在后,說(shuō)明O為重,關(guān)系是根據(jù)O得來(lái)的,那么我們就先新建一些Entity Object吧。在一個(gè)博客系統(tǒng)里最常見(jiàn)的就是User,Blog,Post

一個(gè)用戶有且僅有一個(gè)博客,而一個(gè)博客可以有零篇或者多篇博客文章。根據(jù)這個(gè)描述我們來(lái)建立Entity

Step 1 建立實(shí)體對(duì)象

User

系列文章導(dǎo)航:

走進(jìn)Linq--Linq橫空出世篇

走進(jìn)Linq-輝煌的背后

走進(jìn)Linq-Linq大觀園

不能不說(shuō)的C#特性-對(duì)象集合初始化器

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

不能不說(shuō)的C#特性-擴(kuò)展方法

不能不說(shuō)的C#特性-匿名方法和Lambda表達(dá)式

不能不說(shuō)的C#特性-迭代器(上)及一些研究過(guò)程中的副產(chǎn)品

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

走進(jìn)Linq-Linq to Objects(上)基礎(chǔ)篇

走進(jìn)Linq-Linq to Objects(下)實(shí)例篇

走進(jìn)Linq-Linq to SQL感性認(rèn)識(shí)篇

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

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

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

走進(jìn)Linq-How do I(4)拾遺補(bǔ)零篇第一節(jié)

走進(jìn)Linq-Linq to SQL源代碼賞析 Table的獲取過(guò)程

走進(jìn)Linq-Linq to SQL源代碼賞析之Provider的初始化

走進(jìn)Linq-Linq to SQL源代碼賞析,通過(guò)Linq to SQL看Linq


Step 3:建立映射

對(duì)象也有了,關(guān)系也有了,那剩下的是什么?對(duì),就是映射,我們?cè)鯓訉?duì)象映射到數(shù)據(jù)庫(kù)表上?

我們從最簡(jiǎn)單的Post開(kāi)始吧:

/// 
    
/// 博客文章類
    
/// 這個(gè)類和數(shù)據(jù)庫(kù)里的posts表對(duì)應(yīng),由于
    
/// 類名和表名不一樣,所以需要顯式的指明Table特性的Name屬性
    
/// 如果是一致的則無(wú)需指明了
    
/// 
    [Table(Name="posts")]
    
public class Post
    {
        
/// 
        
/// 文章Id
        
/// 這個(gè)對(duì)應(yīng)posts表里的postid
        
/// 這個(gè)字段還是一個(gè)主鍵,所以Column特性的IsPrimaryKey屬性為true
        
/// 
        [Column(Name="postid",IsPrimaryKey=true)]
        
public int Id { getset; }
        
/// 
        
/// 文章從屬的博客
        
/// 這個(gè)對(duì)應(yīng)著表里的blogid,名字一樣所以只需要加個(gè)Column特性就可以了
        
/// 下面幾個(gè)也是一樣的意思
        
/// 
        [Column]
        
public int BlogId { getset; }
        
/// 
        
/// 標(biāo)題
        
/// 
        [Column]
        
public string Title { getset; }
        
/// 
        
/// 內(nèi)容
        
/// 
        [Column]
        
public string Body { getset; }
        
/// 
        
/// 發(fā)表時(shí)間
        
/// 
        [Column]
        
public DateTime CreateDate { getset; }
}

系列文章導(dǎo)航:

走進(jìn)Linq--Linq橫空出世篇

走進(jìn)Linq-輝煌的背后

走進(jìn)Linq-Linq大觀園

不能不說(shuō)的C#特性-對(duì)象集合初始化器

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

不能不說(shuō)的C#特性-擴(kuò)展方法

不能不說(shuō)的C#特性-匿名方法和Lambda表達(dá)式

不能不說(shuō)的C#特性-迭代器(上)及一些研究過(guò)程中的副產(chǎn)品

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

走進(jìn)Linq-Linq to Objects(上)基礎(chǔ)篇

走進(jìn)Linq-Linq to Objects(下)實(shí)例篇

走進(jìn)Linq-Linq to SQL感性認(rèn)識(shí)篇

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

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

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

走進(jìn)Linq-How do I(4)拾遺補(bǔ)零篇第一節(jié)

走進(jìn)Linq-Linq to SQL源代碼賞析 Table的獲取過(guò)程

走進(jìn)Linq-Linq to SQL源代碼賞析之Provider的初始化

走進(jìn)Linq-Linq to SQL源代碼賞析,通過(guò)Linq to SQL看Linq


實(shí)際上,如果光返回一個(gè)Table,而不在上面施加任何的操作,遍歷的時(shí)候是返回整個(gè)表的數(shù)據(jù),在上一篇我還提到,為了跟蹤,我們最好將dbContext.Log給顯示出來(lái)。如果你添加了下面這行代碼:
dbContext.Log = Console.Out;

系列文章導(dǎo)航:

走進(jìn)Linq--Linq橫空出世篇

走進(jìn)Linq-輝煌的背后

走進(jìn)Linq-Linq大觀園

不能不說(shuō)的C#特性-對(duì)象集合初始化器

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

不能不說(shuō)的C#特性-擴(kuò)展方法

不能不說(shuō)的C#特性-匿名方法和Lambda表達(dá)式

不能不說(shuō)的C#特性-迭代器(上)及一些研究過(guò)程中的副產(chǎn)品

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

走進(jìn)Linq-Linq to Objects(上)基礎(chǔ)篇

走進(jìn)Linq-Linq to Objects(下)實(shí)例篇

走進(jìn)Linq-Linq to SQL感性認(rèn)識(shí)篇

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

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

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

走進(jìn)Linq-How do I(4)拾遺補(bǔ)零篇第一節(jié)

走進(jìn)Linq-Linq to SQL源代碼賞析 Table的獲取過(guò)程

走進(jìn)Linq-Linq to SQL源代碼賞析之Provider的初始化

走進(jìn)Linq-Linq to SQL源代碼賞析,通過(guò)Linq to SQL看Linq


但是不是所有的
C#的方法都可以使用呢?答案是否定的。比如:

var posts = from post in dbContext.GetTable<Post>()
         
where post.Title.StartsWith("y")
         select post.CreateDate.ToString(
"yyyy-MM-dd");

系列文章導(dǎo)航:

走進(jìn)Linq--Linq橫空出世篇

走進(jìn)Linq-輝煌的背后

走進(jìn)Linq-Linq大觀園

不能不說(shuō)的C#特性-對(duì)象集合初始化器

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

不能不說(shuō)的C#特性-擴(kuò)展方法

不能不說(shuō)的C#特性-匿名方法和Lambda表達(dá)式

不能不說(shuō)的C#特性-迭代器(上)及一些研究過(guò)程中的副產(chǎn)品

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

走進(jìn)Linq-Linq to Objects(上)基礎(chǔ)篇

走進(jìn)Linq-Linq to Objects(下)實(shí)例篇

走進(jìn)Linq-Linq to SQL感性認(rèn)識(shí)篇

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

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

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

走進(jìn)Linq-How do I(4)拾遺補(bǔ)零篇第一節(jié)

走進(jìn)Linq-Linq to SQL源代碼賞析 Table的獲取過(guò)程

走進(jìn)Linq-Linq to SQL源代碼賞析之Provider的初始化

走進(jìn)Linq-Linq to SQL源代碼賞析,通過(guò)Linq to SQL看Linq


Step 6:更新數(shù)據(jù)

可以插入肯定就可以更新了,下面就來(lái)看看如何更新呢:

做更新的時(shí)候,你首先得從數(shù)據(jù)庫(kù)查詢出該對(duì)象,然后對(duì)該對(duì)象的屬性進(jìn)行修改,最后更新到數(shù)據(jù)庫(kù):

var posts = from post in dbContext.GetTable<Post>()
        
where post.BlogId == 2
        select post;
foreach (var post in posts)
     post.BlogId 
= 5;

dbContext.SubmitChanges();

it知識(shí)庫(kù)走進(jìn)Linq-Linq to SQL How do I(1),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线播放一区二区精品产 | 日韩欧美一区二区三区免费观看 | 欧洲最大无人区免费高清完整版 | 国产成人精品免费视频大全可播放的 | 99视频精品全部免费观看 | 十分钟免费观看大全视频 | 护士们的母狗 | 抽插H浊水H嫩B父皇 虫族bl文全肉高h | 亚洲一级特黄 | 亚洲中文日韩日本在线视频 | 一级做a爰片久久毛片潮喷动漫 | 日本不卡一二三 | 性生片30分钟 | 麻豆传煤网站网址入口在线下载 | 清冷受被CAO的合不拢 | 日产亚洲一区二区三区 | 先锋影音av资源站av | 空姐被黑人 苏晓曼 | 亚洲精品无码久久久久A片 亚洲精品无码国产爽快A片百度 | 边摸边吃奶边做激情叫床视 | 欧美性爱 成人 | 啪啪漫画无遮挡全彩h网站 啪啪漫画无遮挡全彩h同人 | 97国产精品久久精品国产 | 国产综合视频在线观看一区 | 亚洲一区二区三区91 | 黑人性xxx | 墨西哥美女主播 | 日韩精品专区在线影院重磅 | 欧美精品成人a多人在线观看 | 国产盗摄TP摄像头偷窥 | 花蝴蝶在线观看免费8 | 欧美A级肉欲大片XXX | 欧美熟妇互舔20p | 四虎永久免费网址 | 大学生高潮无套内谢视频 | 蜜桃99影院 | 快播苍井空 | 韩国精品无码少妇在线观看网站 | 美女脱了内裤张开腿让男人爽 | 国产精品毛片AV久久97 | 大香伊人久久精品一区二区 |