色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

走進Linq-Linq to Objects(下)實例篇

系列文章導航:

走進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


理論部分也聊了好幾篇了,從今天開始我們就來進行一些實例,看到代碼才心安點,呵呵。這個例子將貫穿本系列的后續所有篇章。

以博客園為例建模:

博客園里每個用戶有且僅有一個博客,為了簡單每篇博客只能屬于一個分類,每個用戶有一個角色

下面是代碼

public class User
{
/**//// <summary>
/// 用戶編號
/// </summary>
public int UserId { get; set; }
/**//// <summary>
/// 博客園Id
/// </summary>
public string UserName { get; set; }
/**//// <summary>
/// 密碼
/// </summary>
public string Password { get; set; }
/**//// <summary>
/// 博客名稱
/// </summary>
public string BlogName { get; set; }
/**//// <summary>
/// 角色
/// </summary>
public Role Role { get; set; }
}

系列文章導航:

走進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


現在假設博客園程序啟動的時候將數據庫所有數據讀入到內存中(多么荒謬啊,呵呵,僅僅是個假設),填充到上面這些對象里,那我們在內存中就有了這些集合: IList users,IList posts,IList roles,我們現在使用Linq to Objects對這些集合進行各種操作

向查詢表達式傳入參數

現在有一個用戶輸入http://yuyijq.cnblogs.com,通過UrlRewrite,這個連接將轉向到http://www.cnblogs.com/blog.ASPx?u=yuyijq,那現在我們的程序要干些什么呢?首先根據yuyijq讀取該博主的所有帖子。那就要從IList集合里查找出UserName為”yuyijq”的所有帖子,但是顯示在博客首頁上的時候并不需要帖子的內容,如果把帖子內容也讀取的話太耗資源了,只需要博客的標題,然后我們將這個只有標題和摘要的對象的集合綁定到一個GridView上:

var dataSource = from post in posts
              
where post.UserName == "yuyijq"
              select post.Title;
mainGridView.DataSource 
= dataSource;
mainGridView.DataBind();

系列文章導航:

走進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


非泛型集合的查詢

雖然今天C#已經發展到了3.0,但是在2.0里出現的泛型并沒有得到全面的普及,很多開發者還是在程序里大量使用1.x里出現的一些非泛型集合,比如ArrayList就是個代表,那么如果存在這樣一個集合我們怎么去查詢:

ArrayList posts = dataBase.GetAllPosts();

系列文章導航:

走進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


排序

在數據驅動的應用中我們經常需要對數據根據一些屬性進行排序,而通常這些排序的屬性應該是用戶可以自己設置的,比如博客,可以根據點擊率排序,也可以根據評論排序,甚至兩者都作為排序根據。還有什么順序啊,倒序啊,也就是這個排序是個動態的。那我們是不是要寫一大串if…else…進行判斷,然后寫不同的Linq表達式:

if(根據點擊率排序){
    
return from post in posts
        
where post.Title ==”yuyijq”
              orderby post.Click
            select post;
}
else if(…){

}

系列文章導航:

走進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


分組

在上一篇中GroupBy對應的查詢表達式也非常麻煩,下面就來瞧瞧。我們要對博客園上所有文章做個分組,分組依據就根據博客的用戶名好了:

var dataSource = from post in posts
          group post.Title by post.UserName;

系列文章導航:

走進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


聯結

Join也是個蠻復雜的表達式

如果給你一個UserId,你要根據UserId從users集合里先找出UserName,然后根據UserName找出所有下面的Post:

var dataSource = from post in posts
             join user 
in users on post.UserName equals user.UserName
             
where user.UserId = 2
             select post;

it知識庫走進Linq-Linq to Objects(下)實例篇,轉載需保留來源!

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

主站蜘蛛池模板: 玉山县| 平乡县| 平和县| 荣成市| 沧州市| 杭州市| 泽库县| 小金县| 改则县| 嘉义县| 嘉兴市| 东光县| 达尔| 昌江| 涿州市| 内江市| 漳浦县| 灯塔市| 洪湖市| 老河口市| 玛多县| 扶余县| 邵东县| 平凉市| 东兴市| 慈利县| 清镇市| 凤阳县| 延长县| 交口县| 台北市| 长宁区| 秭归县| 闽清县| 诸城市| 福建省| 岐山县| 枝江市| 石林| 宣威市| 安多县|