|
系列文章導(dǎo)航:
不能不說的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 SQL的Case要做的一些事情,主要從細(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í)體對象

系列文章導(dǎo)航:
不能不說的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 { get; set; }
///
/// 文章從屬的博客
/// 這個(gè)對應(yīng)著表里的blogid,名字一樣所以只需要加個(gè)Column特性就可以了
/// 下面幾個(gè)也是一樣的意思
///
[Column]
public int BlogId { get; set; }
///
/// 標(biāo)題
///
[Column]
public string Title { get; set; }
///
/// 內(nèi)容
///
[Column]
public string Body { get; set; }
///
/// 發(fā)表時(shí)間
///
[Column]
public DateTime CreateDate { get; set; }
}
系列文章導(dǎo)航:
不能不說的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)航:
不能不說的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)航:
不能不說的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)系我們修改或刪除,多謝。