成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

C# Lambda Expression使用實例解析

開發 后端
C# Lambda Expression的使用主要是我們LINQ to SQL的實際應用中處理數據的時候會碰到,那么C# Lambda Expression的出現會給我們帶來什么好處呢?那么本文就向你介紹詳細的內容。

我們在LINQ to SQL的實際開發應用中C# Lambda Expression的使用是什么情況呢?尤其是ORM框架使用時會碰到在刪除數據方面的一些問題,就是使用特定條件無法批量刪除數據。那么如何解決這種問題呢?那么這里向你提供了一點思路,希望對你有所幫助。

我們處理一些刪除操作,會選擇寫SQL語句或者執行存儲過程,例如:

  1. ItemDataContext db = new ItemDataContext();  
  2. db.ExecuteCommand(  
  3. "DELETE FROM Item WHERE [CreateTime] < {0}",   
  4. DateTime.UtcNow.AddMonths(-1)); 

C# Lambda Expression的出現

在程序里出現直接的SQL語句是一件很丑陋的事情。在我看來,數據庫操作應該被封裝起來,而對于應用層的開發人員來說,眼中應該只有對象——退一步的話也可向數據庫發送指令(就是使用存儲過程)。當然,這是理想狀態,值得追求,但不可強求。幸運的是C# 3.0所擁有的強大特性足以讓我們對LINQ to SQL的功能進行擴展。為了更好地進行項目開發,以及周五的一次技術交流,我為LINQ to SQL擴展了批量刪除功能。當項目中引用了這個擴展之后,我們就可以使用如下的代碼來實現上面的功能了:

  1. ItemDataContext db = new ItemDataContext();  
  2. db.Items.Delete(item =>   
  3. item.CreateTime < DateTime.UtcNow.AddMonths(-1)); 

當然,擴展還支持更復雜的刪除條件,例如:

  1. ItemDataContext db = new ItemDataContext();  
  2. db.Items.Delete(item =>  
  3. item.CreateTime < DateTime.UtcNow.AddMonths(-1) ||   
  4. item.ViewCount < item.CommentCount && item.UserName != "jeffz");  

之前我對于LINQ to SQL的擴展大都基于DataContext,不過很明顯,這次的擴展是基于Table<T>的。總的來說,這個擴展比我想象中要簡單不少。針對LINQ的擴展最麻煩的地方就在于解析表達式樹(Expression Tree),而這個擴展關鍵的就是二元表達式(BinaryExpression),除了這點就沒有太大問題了——當然,這也是因為我放棄了對于復雜表達式樹的解析,例如現在就不支持“item.Introduction.Length < 10”這種條件,而對于更完整的解析方式來說,應該將其轉化為T-SQL中的LEN函數。

C# Lambda Expression的使用:

這個擴展的關鍵在于根據表達式樹生成Where Condition,我使用三個步驟完成這個擴展,大家可以關注代碼里的相關實現(如果需要的話我也可以在以后進行說明):

◆使用PartialEvaluator將表達式中的常量直接計算出來(例如“3 * 3”表達式將被替換為“9”),同時也會將一些存儲在變量中的值使用常量進行替換。

◆使用ConditionBuilder將表達式中的常量收集起來,并生成帶參數的Condition表達式(例如“[CreateTime] < {0} AND [UserName] <> {1}”)。

◆使用DataContext.ExecuteCommand方法執行完整的SQL語句。

有了批量刪除的功能,那么還缺點什么呢?那自然就是批量更新的功能了。批量更新的功能比刪除略為復雜一些,我正在開發之中。在有了這個擴展之后,我們就可以使用如下的方法進行批量更新了:

  1. ItemDataContext db = new ItemDataContext();  
  2. db.Items.Update(  
  3. item => new Item  
  4. {  
  5. Introduction = item.Title + "Hello World",  
  6. ViewCount = item.ViewCount + 1,  
  7. }, // 更新方式  
  8. item => item.CommentCount > 100 /* 更新條件 */); 

原文來自:http://www.cnblogs.com/zhanglxun/archive/2009/04/21/1440351.html

C# Lambda Expression的使用實例就向你介紹到這里,對于C# Lambda Expression的使用講解希望對你的開發有所幫助。

【編輯推薦】

  1. LINQ刪除記錄的操作實現
  2. 實現LINQ刪除數據的巧妙方法
  3. 詳解實現LINQ to SQL刪除行
  4. C# Lambda Expression概念淺析
  5. 詳解C# Lambda表達式的動態生成
責任編輯:仲衡 來源: 博客園
相關推薦

2009-09-14 13:44:14

Lambda ExprC# Lambda

2009-09-09 14:40:15

C# XML解析

2009-08-18 10:47:40

C#枚舉類型

2009-09-09 13:57:28

C# XML解析

2009-09-07 06:31:32

C#窗體移動

2009-08-26 12:14:44

C#打印設置

2009-08-31 18:17:32

C#接口編程

2009-08-19 16:09:15

C#操作Access

2009-08-31 17:16:12

C#實現接口

2009-08-28 12:31:06

C#靜態方法

2009-08-27 17:40:21

C#接口的作用

2009-08-31 17:30:10

C#接口的作用

2009-09-01 13:51:51

C#創建Word文檔

2009-09-03 09:16:35

C#遞歸函數

2009-09-03 15:43:21

C#時間計算

2009-09-04 13:37:44

C#貨幣格式

2009-09-01 18:32:32

C#動態數組

2009-08-27 15:17:18

C# interfacinterface使用

2024-12-02 00:53:45

IDisposabl工具接口

2011-05-20 17:50:45

C#
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: aaa国产大片| 亚洲一区二区三区四区五区午夜 | 99精品国产一区二区青青牛奶 | 国产欧美一区二区三区国产幕精品 | 成人自拍视频 | 午夜免费电影院 | 亚洲成人综合社区 | 久久久女女女女999久久 | 亚洲精品日韩视频 | 天天躁日日躁狠狠的躁天龙影院 | 欧美国产91| 嫩草影院网址 | 亚洲一区成人 | 国产精品国色综合久久 | 欧美黄色网络 | 欧美老少妇一级特黄一片 | 蜜桃毛片| 国产日韩欧美激情 | 一区二区成人 | 51ⅴ精品国产91久久久久久 | 天天拍天天操 | 精品成人一区二区 | 中文字幕第十页 | 91视频免费 | 精品免费视频 | 国产成人精品免费视频大全最热 | 亚洲综合视频 | 综合激情网 | 男女免费网站 | 免费观看一级特黄欧美大片 | www.亚洲精品 | 亚洲一区中文字幕 | 在线看无码的免费网站 | 黄色网址在线免费观看 | 日本久久综合网 | 国产精品资源在线 | 精品国产女人 | 亚洲资源站 | 国产成在线观看免费视频 | 天天操天天拍 | 黑人成人网 |