LINQ查询操作符之First、FirstOrDefault、Last、LastOrDefault、ElementAt、ElementAtOrDefault、Contains、Any、All、Count

介绍  
    ·First - 返回集合中的第一个元素;不延迟  
    ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟  
    ·Last - 返回集合中的最后一个元素;不延迟  
    ·LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)  
    ·ElementAt - 返回集合中指定索引的元素;不延迟  
    ·ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟  
    ·Contains - 判断集合中是否包含有某一元素;不延迟  
    ·Any - 判断集合中是否有元素满足某一条件;不延迟  
    ·All - 判断集合中是否所有元素都满足某一条件;不延迟  
    ·Count - 返回集合中的元素个数,返回int;不延迟  
    ·LongCount - 返回集合中的元素个数,返回long;不延迟  
    ·Sum - 集合应为数字类型集合,求其和;不延迟  
    ·Min - 返回集合的最小值;不延迟  
    ·Max - 返回集合的最大值;不延迟  
    ·Average - 集合应为数字类型集合,求其平均值;不延迟  
    ·Aggregate - 根据输入的表达式获取一个聚合值;不延迟  
    ·Cast - 将集合转换为强类型集合;延迟  
    ·DefaultIfEmpty - 查询结果为空则返回默认值;延迟  
    ·SequenceEqual - 判断两个集合是否相同;不延迟  
    ·OfType - 过滤集合中的指定类型;延迟  
    ·ToArray - 将集合转换为数组;不延迟  
    ·ToList - 将集合转换为List<T>集合;不延迟  
    ·ToDictionary - 将集合转换为<K, V>集合;不延迟  
  
  
示例  
Summary3.aspx.cs  
using System;  
using System.Data;  
using System.Configuration;  
using System.Collections;  
using System.Linq;  
using System.Web;  
using System.Web.Security;  
using System.Web.UI;  
using System.Web.UI.WebControls;  
using System.Web.UI.WebControls.WebParts;  
using System.Web.UI.HtmlControls;  
using System.Xml.Linq;  
  
using System.Collections.Generic;  
using DAL;  
  
public partial class LINQ_Summary3 : System.Web.UI.Page  
{  
    NorthwindDataContext _ctx = new NorthwindDataContext();  
    string[] _ary = null;  
  
    protected void Page_Load(object sender, EventArgs e)  
    {  
        _ary = new string[] { "asp.net", "csharp", "xhtml", "css", "javascript",   
            "wcf", "wpf", "silverlight", "linq", "wf",   
            "sqlserver", "asp.net ajax", "ssis", "ssas", "ssrs" };  
  
        // First - 返回集合中的第一个元素;不延迟  
        // FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟  
        Summary_First_FirstOrDefault();  
  
        // Last - 返回集合中的最后一个元素;不延迟  
        // LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)  
        Summary_Last_LastOrDefault();  
  
        // ElementAt - 返回集合中指定索引的元素;不延迟  
        // ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟  
        Summary_ElementAt_ElementAtOrDefault();  
  
        // Contains - 判断集合中是否包含有某一元素;不延迟  
        Summary_Contains();  
  
        // Any - 判断集合中是否有元素满足某一条件;不延迟  
        Summary_Any();  
  
        // All - 判断集合中是否所有元素都满足某一条件;不延迟  
        Summary_All();  
  
        // Count - 返回集合中的元素个数,返回int;不延迟  
        // LongCount - 返回集合中的元素个数,返回long;不延迟  
        Summary_Count_LongCount();  
  
        // Sum - 集合应为数字类型集合,求其和;不延迟  
        Summary_Sum();  
  
        // Min - 返回集合的最小值;不延迟  
        Summary_Min();  
  
        // Max - 返回集合的最大值;不延迟  
        Summary_Max();  
  
        // Average - 集合应为数字类型集合,求其平均值;不延迟  
        Summary_Average();  
  
        // Aggregate - 根据输入的表达式获取一个聚合值;不延迟  
        Summary_Aggregate();  
  
        // Cast - 将集合转换为强类型集合;延迟  
        Summary_Cast();  
  
        // DefaultIfEmpty - 查询结果为空则返回默认值;延迟  
        Summary_DefaultIfEmpty();  
  
        // SequenceEqual - 判断两个集合是否相同;不延迟  
        Summary_SequenceEqual();  
  
        // OfType - 过滤集合中的指定类型;延迟  
        Summary_OfType();  
  
        // ToArray - 将集合转换为数组;不延迟  
        Summary_ToArray();  
  
        // ToList - 将集合转换为List<T>集合;不延迟  
        Summary_ToList();  
  
        // ToDictionary - 将集合转换为<K, V>集合;不延迟  
        Summary_ToDictionary();  
    }  
}  
First - 返回集合中的第一个元素;不延迟  
FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟  
    /**//// <summary>  
    /// First - 返回集合中的第一个元素;不延迟  
    /// FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟  
    /// </summary>  
    void Summary_First_FirstOrDefault()  
    {  
        string s = (from a in _ary  
                    select a).First(a => a.StartsWith("s"));  
        // string s = (from a in _ary  
        //             select a).FirstOrDefault(a => a.StartsWith("xxx"));  
        // s == null  
  
        result.InnerHtml += s + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
silverlight  
  
Last - 返回集合中的最后一个元素;不延迟  
LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)  
    /**//// <summary>  
    /// Last - 返回集合中的最后一个元素;不延迟  
    /// LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)  
    /// </summary>  
    void Summary_Last_LastOrDefault()  
    {  
        string s = (from a in _ary  
                    select a).Last(a => a.StartsWith("s"));  
        // string s = (from a in _ary  
        //             select a).LastOrDefault(a => a.StartsWith("sss"));  
        // s == null  
  
        result.InnerHtml += s + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
ssrs  
  
ElementAt - 返回集合中指定索引的元素;不延迟  
ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟  
    /**//// <summary>  
    /// ElementAt - 返回集合中指定索引的元素;不延迟  
    /// ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟  
    /// </summary>  
    void Summary_ElementAt_ElementAtOrDefault()  
    {  
        string s = (from a in _ary  
                    select a).ElementAt(3);  
        // string s = (from a in _ary  
        //             select a).ElementAtOrDefault(1000);  
        // s == null  
  
        result.InnerHtml += s + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
css  
  
Contains - 判断集合中是否包含有某一元素;不延迟  
    /**//// <summary>  
    /// Contains - 判断集合中是否包含有某一元素;不延迟  
    /// </summary>  
    void Summary_Contains()  
    {  
        bool b = (from a in _ary  
                  select a).Contains("javascript");  
  
        result.InnerHtml += b.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
True  
  
Any - 判断集合中是否有元素满足某一条件;不延迟  
    /**//// <summary>  
    /// Any - 判断集合中是否有元素满足某一条件;不延迟  
    /// </summary>  
    void Summary_Any()  
    {  
        bool b = (from a in _ary  
                  select a).Any(p => p.Length > 10);  
  
        result.InnerHtml += b.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
True  
  
All - 判断集合中是否所有元素都满足某一条件;不延迟  
    /**//// <summary>  
    /// All - 判断集合中是否所有元素都满足某一条件;不延迟  
    /// </summary>  
    void Summary_All()  
    {  
        bool b = (from a in _ary  
                  select a).All(p => p.Length > 10);  
  
        result.InnerHtml += b.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
False  
  
Count - 返回集合中的元素个数,返回int;不延迟  
LongCount - 返回集合中的元素个数,返回long;不延迟  
    /**//// <summary>  
    /// Count - 返回集合中的元素个数,返回int;不延迟  
    /// LongCount - 返回集合中的元素个数,返回long;不延迟  
    /// </summary>  
    void Summary_Count_LongCount()  
    {  
        int i = (from a in _ary  
                 select a).Count(p => p.Length > 10);  
        // long i = (from a in _ary  
        //           select a).LongCount(p => p.Length > 10);  
  
        result.InnerHtml += i.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
2  
  
Sum - 集合应为数字类型集合,求其和;不延迟  
    /**//// <summary>  
    /// Sum - 集合应为数字类型集合,求其和;不延迟  
    /// </summary>  
    void Summary_Sum()  
    {  
        int i = (from a in _ary  
                 select a.Length).Sum();  
  
        result.InnerHtml += i.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
87  
  
Min - 返回集合的最小值;不延迟  
    /**//// <summary>  
    /// Min - 返回集合的最小值;不延迟  
    /// </summary>  
    void Summary_Min()  
    {  
        int i = (from a in _ary  
                 select a.Length).Min();  
  
        result.InnerHtml += i.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
2  
  
Max - 返回集合的最大值;不延迟  
    /**//// <summary>  
    /// Max - 返回集合的最大值;不延迟  
    /// </summary>  
    void Summary_Max()  
    {  
        int i = (from a in _ary  
                 select a.Length).Max();  
  
        result.InnerHtml += i.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
12  
  
Average - 集合应为数字类型集合,求其平均值;不延迟  
    /**//// <summary>  
    /// Average - 集合应为数字类型集合,求其平均值;不延迟  
    /// </summary>  
    void Summary_Average()  
    {  
        double d = (from a in _ary  
                    select a.Length).Average();  
  
        result.InnerHtml += d.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
5.8  
  
Aggregate - 根据输入的表达式获取一个聚合值;不延迟  
    /**//// <summary>  
    /// Aggregate - 根据输入的表达式获取一个聚合值;不延迟  
    /// </summary>  
    void Summary_Aggregate()  
    {  
        // 以下算法的Aggregate相当于Sum  
        double d = (from a in _ary  
                    select a.Length).Aggregate((x, y) => x + y);  
  
        result.InnerHtml += d.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
87  
  
Cast - 将集合转换为强类型集合;延迟  
    /**//// <summary>  
    /// Cast - 将集合转换为强类型集合;延迟  
    /// </summary>  
    void Summary_Cast()  
    {  
        ArrayList al = new ArrayList();  
        al.Add("asp.net");  
        al.Add("csharp");  
        al.Add("xhtml");  
  
        var list = al.Cast<string>();  
  
        foreach (string s in list)  
        {  
            result.InnerHtml += s + "<br />";  
        }  
        result.InnerHtml += "<br />";  
    }运行结果  
asp.net  
csharp  
xhtml  
  
DefaultIfEmpty - 查询结果为空则返回默认值;延迟  
    /**//// <summary>  
    /// DefaultIfEmpty - 查询结果为空则返回默认值;延迟  
    /// </summary>  
    void Summary_DefaultIfEmpty()  
    {  
        var list = (from a in _ary  
                    where a.Length > 100  
                    select a).DefaultIfEmpty("xxx");  
  
        foreach (string s in list)  
        {  
            result.InnerHtml += s + "<br />";  
        }  
        result.InnerHtml += "<br />";  
    }运行结果  
xxx  
  
SequenceEqual - 判断两个集合是否相同;不延迟  
    /**//// <summary>  
    /// SequenceEqual - 判断两个集合是否相同;不延迟  
    /// </summary>  
    void Summary_SequenceEqual()  
    {  
        bool b = (from a in _ary  
                  where a.Length > 10  
                  select a).SequenceEqual(from a in _ary  
                                          where a.Length > 10  
                                          select a);  
  
        result.InnerHtml += b.ToString() + "<br />";  
        result.InnerHtml += "<br />";  
    }运行结果  
True  
  
OfType - 过滤集合中的指定类型;延迟  
    /**//// <summary>  
    /// OfType - 过滤集合中的指定类型;延迟  
    /// </summary>  
    void Summary_OfType()  
    {  
        object[] objects = { 1, "a", 2, "b", 3, "c" };  
  
        var list = objects.OfType<string>();  
  
        foreach (string s in list)  
        {  
            result.InnerHtml += s + "<br />";  
        }  
        result.InnerHtml += "<br />";  
    }运行结果  
a  
b  
c  
  
ToArray - 将集合转换为数组;不延迟  
    /**//// <summary>  
    /// ToArray - 将集合转换为数组;不延迟  
    /// </summary>  
    void Summary_ToArray()  
    {  
        string[] ary = (from p in _ctx.Products  
                        where p.ProductName.Length > 30  
                        select p.ProductName).ToArray();  
  
        foreach (string s in ary)  
        {  
            result.InnerHtml += s + "<br />";  
        }  
        result.InnerHtml += "<br />";  
    }运行结果  
Jack's New England Clam Chowder  
Louisiana Fiery Hot Pepper Sauce  
Original Frankfurter grüne So?e  
Uncle Bob's Organic Dried Pears  
  
ToList - 将集合转换为List<T>集合;不延迟  
    /**//// <summary>  
    /// ToList - 将集合转换为List<T>集合;不延迟  
    /// </summary>  
    void Summary_ToList()  
    {  
        var list = (from a in _ary  
                    where a.Length > 10  
                    select a).ToList();  
  
        foreach (string s in list)  
        {  
            result.InnerHtml += s + "<br />";  
        }  
        result.InnerHtml += "<br />";  
    }运行结果  
silverlight  
asp.net ajax  
  
ToDictionary - 将集合转换为<K, V>集合;不延迟  
    /**//// <summary>  
    /// ToDictionary - 将集合转换为<K, V>集合;不延迟  
    /// </summary>  
    void Summary_ToDictionary()  
    {  
        var dic = (from p in _ctx.Products  
                   where p.ProductName.Length > 30  
                   select p).ToDictionary(p => p.ProductID);  
  
        foreach (var p in dic)  
        {  
            result.InnerHtml += p.Key + "" + p.Value.ProductName + "<br />";  
        }  
        result.InnerHtml += "<br />";  
    }运行结果  
7:Uncle Bob's Organic Dried Pears  
41:Jack's New England Clam Chowder  
65:Louisiana Fiery Hot Pepper Sauce  
77:Original Frankfurter grüne So?e  

 

posted @ 2017-04-07 09:58  jake1987  阅读(3117)  评论(0编辑  收藏  举报