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

走進Linq-How do I(4)拾遺補零篇第一節

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

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

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

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

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


最近很忙,真的很忙,所以這個系列好久沒更新了,從今天起我又開始了我的走進Linq之旅。Linq to SQL的用法基本上都說完了,還有一些細枝末節的地方需要聊聊。

強類型DataContext

Linq to SQL的第一篇的時候就說道DataContext是一個入口點,我們使用Linq to SQL做的一些操作幾乎都是施加在這個類上的。在使用VS的設計器生成的代碼里,我們會看到一個從DataContext繼承的局部類,大家都習慣的將這個類稱之為強類型的DataContext,她對DataContext做了進一步的封裝。

今天我們先就對DataContext一些沒有介紹過的地方詳細討論一下。

首先我們先手寫一個強類型的DataContext:

強類型的DataContext

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

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

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

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

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


DataContext還有幾個我們比較感興趣的方法:

ExecuteCommandExecuteQuery<TResult>Translate

這幾個方法都是為了和傳統的ADO.NET集成的。

ExecuteCommand可以做insert,update,delete操作,第一個參數接受一個格式化的sql語句,第二個參數是參數數組:

使用起來很簡單:

dbCtx.ExecuteCommand("insert into posts(blogid,title,body) values({0},{1},{2})", "2", "走進Linq-How do I(4)", "廢話一篇");

ExecuteQuery<TResult>方法呢?顧名思義,就是執行查詢的,也有兩個參數,第一個接受查詢的SQL語句,第二個接受參數,返回一個IEnumerable<T>對象:

IEnumerable<Post> posts = dbCtx.ExecuteQuery<Post>("select * from posts where postid = {0}", "1");

            foreach (var post in posts)

                Console.WriteLine(post.Title);

Translate方法是將以前的DataReader轉換為現在的Linq to SQL方式,這樣有什么好處呢:

1.       可以利用現在的映射,不再需要這樣的語句post.Title = dr[1].ToString();

2.       可以使用查詢表達式的語法

 

對于插入,更新,刪除這些經常使用的操作,為了提高性能,或者做一些自定義的操作,你還可以覆蓋微軟默認為你提供的Insert,Update等方法:

1.       寫一個存儲過程

CREATE PROCEDURE dbo.CreatePost

(

@blogid int,

@title nvarchar(50),

@body nvarchar(500)

       )

AS

insert into posts(blogid,title,body) values(@blogid,@title,@body)

RETURN

 

當然,這個存儲過程非常簡單,不值得這么去做,你就假設存在一個復雜的存儲過程

2.       Posts表拖到設計器上,上面的存儲過程拖到方法設計器上

3.       右鍵點擊設計器上的表,在右鍵菜單里會有一項:配置行為(Config Behavior)

 

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

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

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

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

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

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

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

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

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

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

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

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




這樣就可以用你自定義的存儲過程做插入操作了。

 

 

Linq to SQL中的事務

事務這個東西在并發的時候特別重要,Linq to SQL本身就支持事務,不過是樂觀鎖。我們也可以顯式的啟動Linq to SQL的事務。

            dbCtx.Transaction = dbCtx.Connection.BeginTransaction();

            try

            {

                dbCtx.ExecuteCommand("insert into posts(blogid,title,body) values({0},{1},{2})", "2", "走進Linq-How do I(4)", "廢話一篇");

                dbCtx.ExecuteCommand("insert into posts(blogid,title,body) values({0},{1},{2})", "3", "走進Linq-How do I(5)", "廢話兩篇");

                dbCtx.Transaction.Commit();

            }

            catch

            {

                dbCtx.Transaction.Rollback();

            }

DbConnectionBeginTransaction方法還可以接受一個枚舉參數IsolationLevel,來指定事務隔離的級別。

對于那些多個DataContext之間的事務,我們可以使用.NET 2.0引入的TransactionScope

 

下一篇談談RowVersion的問題

 

it知識庫走進Linq-How do I(4)拾遺補零篇第一節,轉載需保留來源!

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

主站蜘蛛池模板: 中文字幕亚洲乱码熟女在线萌芽 | 亚洲熟女丰满多毛XXXXX | 国产在线观看香蕉视频 | 欧美亚洲日韩在线在线影院 | 风情韵味人妻HD | 97久久伊人精品影院 | 国产亚洲精品首页在线播放 | 国产免费麻传媒精品国产AV | 亚洲欧美精品无码大片在线观看 | 同时被两个男人轮流舔 | 黄色天堂网 | 100国产精品人妻无码 | 午夜DV内射一区二区 | 玖玖爱在线播放 | 好好的曰com久久 | 在线观看精品视频看看播放 | 伦理电影2499伦理片 | 神马电影我不卡4k手机在线观看 | 99国内精品久久久久久久清纯 | 久久精品国产首叶 | 俄罗斯性xxxx | 9797在线看片亚洲精品 | 欧美日韩1区 | 久久妇女高潮几次MBA | 亚洲 日韩 欧美 国产专区 | 极品少妇高潮啪啪AV无码吴梦梦 | 久久亚洲A片COM人成A | 一区二区不卡在线视频 | 国产午夜精品自在自线之la | 亚洲精品国产高清嫩草影院 | 国产午夜三区视频在线 | 97午夜理论片影院在线播放 | 色多多污污版免费下载安装 | 成年人在线视频免费观看 | 和搜子的日子 在线观看 | 亚洲欧美成人无码久久久 | 新新电影理论中文字幕 | 欧美精品成人a多人在线观看 | 怡春院欧美一区二区三区免费 | 久久AV无码AV高潮AV不卡 | av天堂电影网在线观看 |