天天躁日日躁狠狠躁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)系我們修改或刪除,多謝。

主站蜘蛛池模板: 性虎成人网| 成人a视频片在线观看免费 成人a毛片久久免费播放 | 国产午夜视频在线 | 国产Av男人的天堂精品良久 | a级全黄试频试看30分钟 | 翁公与小莹在客厅激情 | 果冻传媒APP免费网站在线观看 | 国产激情视频在线观看 | blacked黑人战小美女 | 亚洲AV无码乱码国产精品品麻豆 | 99这里有精品视频视频 | 高h肉文np | 午夜深情在线观看免费 | 最近中文字幕无吗免费高清 | 国产成人免费a在线资源 | 动漫成年美女黄漫网站 | 青青青青青青青草 | 国产露脸A片国语露对白 | 桃花论坛POWERED2019 | 精品无码久久久久久久久 | 国产精品乱码色情一区二区视频 | 99亚洲精品色情无码久久 | 国产精品欧美一区二区在线看 | 午夜影院费试看黄 | 亚州AV人片一区二区三区99久 | 乳女教师欲乱动漫无修版动画 | 琪琪SEE色原网色原网站18 | 欧美精品色婷婷五月综合 | 亚欧视频在线观看 | 野花香在线观看免费高清播放视频 | 我半夜摸妺妺的奶C了她 | 丰满少妇69激情啪啪无码 | 校园女教师之禁区 | 老阿姨才是最有味的一区二区 | 饥渴的新婚女教师 | 欧美精品成人a多人在线观看 | 热久久国产欧美一区二区精品 | 极品内射少妇精品无码视频 | 岛国大片在线播放免费 | 99蜜桃在线观看免费视频网站 | 国产成人无码免费精品果冻传媒 |