一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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

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

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

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

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

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

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

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

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

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

不能不說的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的獲取過程

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

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


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

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

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

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

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

User

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

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

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

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

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

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

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

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

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

不能不說的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的獲取過程

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

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


Step 3:建立映射

對象也有了,關(guān)系也有了,那剩下的是什么?對,就是映射,我們怎樣將對象映射到數(shù)據(jù)庫表上?

我們從最簡單的Post開始吧:

/// 
    
/// 博客文章類
    
/// 這個(gè)類和數(shù)據(jù)庫里的posts表對應(yīng),由于
    
/// 類名和表名不一樣,所以需要顯式的指明Table特性的Name屬性
    
/// 如果是一致的則無需指明了
    
/// 
    [Table(Name="posts")]
    
public class Post
    {
        
/// 
        
/// 文章Id
        
/// 這個(gè)對應(yīng)posts表里的postid
        
/// 這個(gè)字段還是一個(gè)主鍵,所以Column特性的IsPrimaryKey屬性為true
        
/// 
        [Column(Name="postid",IsPrimaryKey=true)]
        
public int Id { getset; }
        
/// 
        
/// 文章從屬的博客
        
/// 這個(gè)對應(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大觀園

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

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

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

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

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

不能不說的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的獲取過程

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

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


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

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

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

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

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

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

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

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

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

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

不能不說的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的獲取過程

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

走進(jìn)Linq-Linq to SQL源代碼賞析,通過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大觀園

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

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

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

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

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

不能不說的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的獲取過程

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

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


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

可以插入肯定就可以更新了,下面就來看看如何更新呢:

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

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í)庫走進(jìn)Linq-Linq to SQL How do I(1),轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 亚洲综合色播 | 91久久精品在这里色伊人6882 | 精品久久中文久久久 | 92看片淫黄大片看国产片 | 男女男精品视频免费观看 | 免费视频不卡一区二区三区 | 国产视频中文字幕 | 综合区小说区图片区在线一区 | 美女胸免费视频网站 | 亚洲成人伊人网 | 国产xxxxx在线观看 | 日本一区二区高清不卡 | 久久综合丝袜长腿丝袜 | 在线视频一区二区三区在线播放 | 免费黄色在线观看 | 国产福利在线观看 极品美女 | 91精品国产91久久 | 男人精品一线视频在线观看 | 日韩专区亚洲国产精品 | 久久er精品 | 秋霞影音先锋一区二区 | 91精品国产人成网站 | 欧美日韩色视频在线观看 | 亚州视频一区 | 一区二区精品视频 | 国产精品视频一区牛牛视频 | 亚洲精品短视频 | 丁香五月情 | 久久网综合| 国产白白视频在线观看2 | 精品免费久久久久久久 | 91精品视频免费在线观看 | 99在线精品日韩一区免费国产 | 国产91激情对白露脸全程 | 天天拍夜夜添久久精品免费 | 青草国产在线观看 | www.加勒比.com| 四虎影视永久在线 yin56xyz | 色天使色婷婷在线影院亚洲 | 国产久爱青草视频在线观看 | 九九久久精品视频 |