介绍
    ·Select - Select选择;延迟
    ·Where - Where查询;延迟
    ·OrderBy - 按指定表达式对集合正序排序;延迟
    ·OrderByDescending - 按指定表达式对集合倒序排序;延迟
    ·GroupBy - 分组;延迟
    ·Join - Join查询;延迟
    ·GroupJoin - 分组Join查询;延迟
    ·以上查询操作符所对应的查询语法

示例
Summary.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_Summary : 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" };

                // Select - Select选择;延迟
                Summary_Select();

                // Where - Where查询;延迟
                Summary_Where();

                // OrderBy - 按指定表达式对集合正序排序;延迟
                // OrderByDescending - 按指定表达式对集合倒序排序;延迟
                Summary_OrderBy_OrderByDescending();

                // GroupBy - 分组;延迟
                Summary_GroupBy();

                // Join - Join查询;延迟
                Summary_Join();

                // GroupJoin - 分组Join查询;延迟
                Summary_GroupJoin();
        }
}
 
Select - Select选择;延迟
/// <summary>
        /// Select - Select选择;延迟
        /// </summary>
        void Summary_Select()
        {
                // 使用Select查询操作符
                var categories = _ctx.Categories.Select(
                        c => new { CategoryName = "类别名称:" + c.CategoryName });

                foreach (var c in categories)
                {
                        result.InnerHtml += c.CategoryName + "<br />";
                }
                result.InnerHtml += "<br />";


                // 与上面的Select查询操作符相对应的查询语法
                var categories2 = from c in _ctx.Categories
                                                    select new { CategoryName = "类别名称:" + c.CategoryName };

                foreach (var c in categories2)
                {
                        result.InnerHtml += c.CategoryName + "<br />";
                }
                result.InnerHtml += "<br />";
        }
 
运行结果
类别名称:Beverages
类别名称:Condiments
类别名称:Confections
类别名称:Dairy Products
类别名称:Grains/Cereals
类别名称:Meat/Poultry
类别名称:Produce
类别名称:Seafood

Where - Where查询;延迟

/// <summary>
        /// Where - Where查询;延迟
        /// </summary>
        void Summary_Where()
        {
                // 使用Where查询操作符
                var ary = _ary.Where(a => a.StartsWith("w") && a.EndsWith("f"));

                foreach (string s in ary)
                {
                        result.InnerHtml += s + "<br />";
                }
                result.InnerHtml += "<br />";


                // 与上面的Where查询操作符相对应的查询语法
                var ary2 = from a in _ary
                                     where a.StartsWith("w") && a.EndsWith("f")
                                     select a;

                foreach (string s in ary2)
                {
                        result.InnerHtml += s + "<br />";
                }
                result.InnerHtml += "<br />";
        }
 
运行结果
wcf
wpf
wf

OrderBy - 按指定表达式对集合正序排序;延迟
OrderByDescending - 按指定表达式对集合倒序排序;延迟

/// <summary>
        /// OrderBy - 按指定表达式对集合正序排序;延迟
        /// OrderByDescending - 按指定表达式对集合倒序排序;延迟
        /// </summary>
        void Summary_OrderBy_OrderByDescending()
        {
                // 使用OrderBy查询操作符
                var ary = (from a in _ary
                                     select a).OrderBy(a => a.Length); // OrderByDescending与OrderBy用法相同

                foreach (string s in ary)
                {
                        result.InnerHtml += s + "<br />";
                }
                result.InnerHtml += "<br />";


                // 与上面的OrderBy查询操作符相对应的查询语法
                var ary2 = from a in _ary
                                     orderby a.Length ascending // orderby xxx descending与orderby xxx ascending用法相同
                                     select a;

                foreach (string s in ary2)
                {
                        result.InnerHtml += s + "<br />";
                }
                result.InnerHtml += "<br />";
        }
 
运行结果
wf
css
wcf
wpf
linq
ssis
ssas
ssrs
xhtml
csharp
asp.net
sqlserver
javascript
silverlight
asp.net ajax

GroupBy - 分组;延迟

/// <summary>
        /// GroupBy - 分组;延迟
        /// </summary>
        void Summary_GroupBy()
        {
                // 使用GroupBy查询操作符
                var list = (from a in _ary
                                        select a).GroupBy(a => a.Length).Select(
                                                g => new { Group = g.Key, Member = g });

                foreach (var g in list)
                {
                        result.InnerHtml += g.Group + "个字符:<br />";

                        foreach (string s in g.Member)
                        {
                                result.InnerHtml += "--" + s + "<br />";
                        }
                }
                result.InnerHtml += "<br />";


                // 与上面的GroupBy查询操作符相对应的查询语法
                var list2 = from a in _ary
                                        group a by a.Length into g
                                        select new { Group = g.Key, Member = g };

                foreach (var g in list2)
                {
                        result.InnerHtml += g.Group + "个字符:<br />";

                        foreach (string s in g.Member)
                        {
                                result.InnerHtml += "--" + s + "<br />";
                        }
                }
                result.InnerHtml += "<br />";
        }
 
 
运行结果
7个字符:
--asp.net
6个字符:
--csharp
5个字符:
--xhtml
3个字符:
--css
--wcf
--wpf
10个字符:
--javascript
11个字符:
--silverlight
4个字符:
--linq
--ssis
--ssas
--ssrs
2个字符:
--wf
9个字符:
--sqlserver
12个字符:
--asp.net ajax

Join - Join查询;延迟

/// <summary>
        /// Join - Join查询;延迟
        /// </summary>
        void Summary_Join()
        {
                // 使用Join查询操作符
                var products = _ctx.Products.Join(
                        _ctx.Categories,    
                        p => p.CategoryID,    
                        c => c.CategoryID,    
                        (p, c) => new { c.CategoryName, p.ProductName }).Take(5);

                foreach (var p in products)
                {
                        result.InnerHtml += p.CategoryName + " - " + p.ProductName + "<br />";
                }
                result.InnerHtml += "<br />";


                // 与上面的Join查询操作符相对应的查询语法
                var products2 = (from p in _ctx.Products
                                                 join c in _ctx.Categories
                                                 on p.CategoryID equals c.CategoryID
                                                 select new { c.CategoryName, p.ProductName }).Take(5);

                foreach (var p in products2)
                {
                        result.InnerHtml += p.CategoryName + " - " + p.ProductName + "<br />";
                }
                result.InnerHtml += "<br />";
        }
 
运行结果
Beverages - Chai
Beverages - Chang
Condiments - Aniseed Syrup
Condiments - Chef Anton's Cajun Seasoning
Condiments - Chef Anton's Gumbo Mix

GroupJoin - 分组Join查询;延迟

/// <summary>
        /// GroupJoin - 分组Join查询;延迟
        /// </summary>
        void Summary_GroupJoin()
        {
                // 使用GroupJoin查询操作符
                var products = _ctx.Categories.GroupJoin(
                        _ctx.Products,    
                        c => c.CategoryID,    
                        p => p.CategoryID,    
                        (p, g) => new { p.CategoryName, ProductCount = g.Count() });

                foreach (var g in products)
                {
                        result.InnerHtml += g.CategoryName + ":" + g.ProductCount + "<br />";

                }
                result.InnerHtml += "<br />";


                // 与上面的GroupJoin查询操作符相对应的查询语法
                var products2 = from c in _ctx.Categories
                                                join p in _ctx.Products on c.CategoryID equals p.CategoryID into g
                                                select new { CategoryName = c.CategoryName, ProductCount = g.Count() };


                foreach (var g in products2)
                {
                        result.InnerHtml += g.CategoryName + ":" + g.ProductCount + "<br />";

                }
                result.InnerHtml += "<br />";
        }
 
运行结果
Beverages:12
Condiments:12
Confections:13
Dairy Products:10
Grains/Cereals:7
Meat/Poultry:6
Produce:5
Seafood:12

.NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending的更多相关文章

  1. LINQ查询操作符之Select、Where、OrderBy、OrderByDescending、GroupBy、Join、GroupJoin及其对应的查询语法

    介绍    ·Select - Select选择:延迟    ·Where - Where查询:延迟    ·OrderBy - 按指定表达式对集合正序排序:延迟    ·OrderByDescend ...

  2. Linq基础操作之Select,Where,OrderBy,ThenBy源码分析

    Linq基础操作之Select,Where,OrderBy,ThenBy源码分析 二:Select 它是延迟执行.yield有得一拼,因为他们都是生成了一个枚举类. if (source is TSo ...

  3. LINQ查询操作符 LINQ学习第二篇[转]

    一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataCo ...

  4. LINQ查询操作符 LINQ学习第二篇

    一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataCo ...

  5. LINQ查询操作符

    ·First - 返回集合中的第一个元素:不延迟 ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值):不延迟 ·Last - 返回集合中的最后一个元素:不延迟 ·Las ...

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

    ·First - 返回集合中的第一个元素:不延迟 ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值):不延迟 ·Last - 返回集合中的最后一个元素:不延迟 ·Las ...

  7. C#编程(六十二)---------LINQ标准的查询操作符

    LINQ标准的查询操作符 首先我们来看一下LINQ的操作符,可根据查询操作符的操作”类型”进行分类,如把它们分成投影,限制,排序,联接,分组,串联,聚合,集合,生成,转换,元素,相等,量词,分割等. ...

  8. 2.3 LINQ查询表达式中 使用select子句 指定目标数据

    本篇讲解LINQ查询的三种形式: 查询对象 自定义查询对象某个属性 查询匿名类型结果 [1.查询结果返回集合元素] 在LINQ查询中,select子句和from子句都是必备子句.LINQ查询表达式必须 ...

  9. 转linq中的Single()、First()、Take(1) LINQ 标准的查询操作符 排序 orderby、thenby、Take

    Single():操作一个集合,同时强要求只有一个对象匹配,并返回这一个. First():操作一个集合,可以有多个对象匹配,但是只返回第一个. Take(1):操作一个集合,可以有对个对象匹配,单只 ...

随机推荐

  1. NET基础课--异常处理X

    通常不建议如下的捕获方式  正确的方法是:某一功能函数的入口捕获基本异常即exception,分支方法或片段方法中捕获特定异常 高级: 另附:Fxcop异常监控工具

  2. vs2010 中检测到有潜在危险的 Request.Form 值

    解决方法 : 一般在网上搜只有以下两种处理方式: 1.在报错的页面前吧<%Page%>标签中增加validateRequest="false"的属性为false 如下所 ...

  3. Sql Server 2012启动存储过程

    可以通过如下步骤创建 1.打开show advanced options reconfigure 2.打开scan for startup procs,使得sql server在启动时扫描需要运行的p ...

  4. [转载]浅析Windows安全相关的一些概念

    Session 我们平常所说的Session是指一次终端登录, 这里的终端登录是指要有自己的显示器和鼠标键盘等, 它包括本地登录和远程登录.在XP时代每次终端登录才会创建一个Session,但是在Vi ...

  5. 【Lucene4.8教程之一】使用Lucene4.8进行索引及搜索的基本操作

    在Lucene对文本进行处理的过程中,可以大致分为三大部分: 1.索引文件:提取文档内容并分析,生成索引 2.搜索内容:搜索索引内容,根据搜索关键字得出搜索结果 3.分析内容:对搜索词汇进行分析,生成 ...

  6. SQL Server 引起磁盘IO的原因

    1. 要访问的数据不在内存中.这会引起IO 2. update/delete/insert 会把变化写入数据文件.还要记录日志 : 3. checkpoint 4. lazy writer 5. db ...

  7. shell基础——二元比较操作符

    二元比较操作符,比较变量或者比较数字.注意数字与字符串的区别. 整数比较 -eq 等于,如:if [ "$a" -eq "$b" ]-ne 不等于,如:if [ ...

  8. MEMS陀螺仪(gyroscope)的工作原理

    传统的陀螺仪主要是利用角动量守恒原理,因此它主要是一个不停转动的物体,它的转轴指向不随承载它的支架的旋转而变化. 但是MEMS陀螺仪(gyroscope)的工作原理不是这样的,因为要用微机械技术在硅片 ...

  9. 在C#中调用Win32函数EnumWindows枚举所有窗口。

    原文 http://www.cnblogs.com/mfm11111/archive/2009/06/30/1514322.html 开发旺旺群发软件,难点及重要技术点分析(一) 一.        ...

  10. Android Activity跳转动画,让你的APP瞬间绚丽起来

    我们都知道绚丽的APP总会给用户耳目一新的感觉,为了抓住用户更大网络公司使出浑身解数让自己的产品更绚丽,而绚丽最简单的效果就是Activity跳转效果,不仅可以让用户看起来舒服,而且实现起来也特别简单 ...