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

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

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

走進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)拾遺補零篇第一節(jié)

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

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

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


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

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

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

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

Step 1 建立實體對象

User

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

走進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)拾遺補零篇第一節(jié)

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

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

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


Step 3:建立映射

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

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

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

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

走進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)拾遺補零篇第一節(jié)

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

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

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


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

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

走進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)拾遺補零篇第一節(jié)

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

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

走進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");

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

走進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)拾遺補零篇第一節(jié)

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

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

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


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

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

做更新的時候,你首先得從數(shù)據(jù)庫查詢出該對象,然后對該對象的屬性進行修改,最后更新到數(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知識庫走進Linq-Linq to SQL How do I(1),轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 视色4se000| 亚洲欧美国产日产综合不卡 | 四虎国产精品视频免费看 | 国产伦精品一区二区三区 | 在线观看亚洲精品国产 | 亚洲国产欧美91 | 激情综合五月婷婷 | 亚洲欧美一区二区三区四区 | 免费高清视频日本 | 91精品国产一区 | 成人福利免费在线观看 | 亚洲国产精品婷婷久久久久 | 日本一区二区三区四区公司 | 看黄在线 | 欧美一区二区三区精品国产 | 国产成人综合亚洲亚洲欧美 | 91秒拍国产福利一区 | 亚洲图片欧美小说 | 国产美女免费国产 | 三级黄网站 | 在线亚洲欧美性天天影院 | 丁香婷婷综合五月综合色啪 | 免费在线国产视频 | 欧美黑人两根巨大挤入 | 国产精品天天看特色大片不卡 | www.日本精品| 亚洲天堂久久精品成人 | 久久国产偷| 99视频精品全部免费观看 | 欧美成人福利视频 | 中文字幕一区在线观看视频 | 欧美日韩在线视频 | 337q日本大胆欧美人术艺术 | 亚洲国内精品 | 九一国产精品 | 好吊色49paopao视频 | 91亚洲视频在线观看 | 五月婷婷丁香在线视频 | 91久久99久91天天拍拍 | 一区二区3区免费视频 | 色哟哟视频在线 |