码迷,mamicode.com
首页 > Web开发 > 详细

.NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending

时间:2014-09-15 15:52:59      阅读:332      评论:0      收藏:0      [点我收藏+]

标签:des   blog   http   io   os   使用   java   ar   for   

 



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


示例
Summary.aspx.cs
bubuko.com,布布扣using System;
bubuko.com,布布扣using System.Data;
bubuko.com,布布扣using System.Configuration;
bubuko.com,布布扣using System.Collections;
bubuko.com,布布扣using System.Linq;
bubuko.com,布布扣using System.Web;
bubuko.com,布布扣using System.Web.Security;
bubuko.com,布布扣using System.Web.UI;
bubuko.com,布布扣using System.Web.UI.WebControls;
bubuko.com,布布扣using System.Web.UI.WebControls.WebParts;
bubuko.com,布布扣using System.Web.UI.HtmlControls;
bubuko.com,布布扣using System.Xml.Linq;
bubuko.com,布布扣
bubuko.com,布布扣using System.Collections.Generic;
bubuko.com,布布扣using DAL;
bubuko.com,布布扣
bubuko.com,布布扣public partial class LINQ_Summary : System.Web.UI.Page
bubuko.com,布布扣{
bubuko.com,布布扣        NorthwindDataContext _ctx = new NorthwindDataContext();
bubuko.com,布布扣        string[] _ary = null;
bubuko.com,布布扣
bubuko.com,布布扣        protected void Page_Load(object sender, EventArgs e)
bubuko.com,布布扣        {
bubuko.com,布布扣                _ary = new string[] { "asp.net", "csharp", "xhtml", "css", "javascript",    
bubuko.com,布布扣                        "wcf", "wpf", "silverlight", "linq", "wf",    
bubuko.com,布布扣                        "sqlserver", "asp.net ajax", "ssis", "ssas", "ssrs" };
bubuko.com,布布扣
bubuko.com,布布扣                // Select - Select选择;延迟
bubuko.com,布布扣                Summary_Select();
bubuko.com,布布扣
bubuko.com,布布扣                // Where - Where查询;延迟
bubuko.com,布布扣                Summary_Where();
bubuko.com,布布扣
bubuko.com,布布扣                // OrderBy - 按指定表达式对集合正序排序;延迟
bubuko.com,布布扣                // OrderByDescending - 按指定表达式对集合倒序排序;延迟
bubuko.com,布布扣                Summary_OrderBy_OrderByDescending();
bubuko.com,布布扣
bubuko.com,布布扣                // GroupBy - 分组;延迟
bubuko.com,布布扣                Summary_GroupBy();
bubuko.com,布布扣
bubuko.com,布布扣                // Join - Join查询;延迟
bubuko.com,布布扣                Summary_Join();
bubuko.com,布布扣
bubuko.com,布布扣                // GroupJoin - 分组Join查询;延迟
bubuko.com,布布扣                Summary_GroupJoin();
bubuko.com,布布扣        }
bubuko.com,布布扣}
 
Select - Select选择;延迟
/// <summary>
bubuko.com,布布扣        /// Select - Select选择;延迟
bubuko.com,布布扣        /// </summary>
bubuko.com,布布扣        void Summary_Select()
bubuko.com,布布扣        {
bubuko.com,布布扣                // 使用Select查询操作符
bubuko.com,布布扣                var categories = _ctx.Categories.Select(
bubuko.com,布布扣                        c => new { CategoryName = "类别名称:" + c.CategoryName });
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var c in categories)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += c.CategoryName + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                // 与上面的Select查询操作符相对应的查询语法
bubuko.com,布布扣                var categories2 = from c in _ctx.Categories
bubuko.com,布布扣                                                    select new { CategoryName = "类别名称:" + c.CategoryName };
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var c in categories2)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += c.CategoryName + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣        }
 
运行结果
类别名称:Beverages
类别名称:Condiments
类别名称:Confections
类别名称:Dairy Products
类别名称:Grains/Cereals
类别名称:Meat/Poultry
类别名称:Produce
类别名称:Seafood

Where - Where查询;延迟
/// <summary>
bubuko.com,布布扣        /// Where - Where查询;延迟
bubuko.com,布布扣        /// </summary>
bubuko.com,布布扣        void Summary_Where()
bubuko.com,布布扣        {
bubuko.com,布布扣                // 使用Where查询操作符
bubuko.com,布布扣                var ary = _ary.Where(a => a.StartsWith("w") && a.EndsWith("f"));
bubuko.com,布布扣
bubuko.com,布布扣                foreach (string s in ary)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += s + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                // 与上面的Where查询操作符相对应的查询语法
bubuko.com,布布扣                var ary2 = from a in _ary
bubuko.com,布布扣                                     where a.StartsWith("w") && a.EndsWith("f")
bubuko.com,布布扣                                     select a;
bubuko.com,布布扣
bubuko.com,布布扣                foreach (string s in ary2)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += s + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣        }
 
运行结果
wcf
wpf
wf

OrderBy - 按指定表达式对集合正序排序;延迟
OrderByDescending - 按指定表达式对集合倒序排序;延迟
bubuko.com,布布扣 /// <summary>
bubuko.com,布布扣        /// OrderBy - 按指定表达式对集合正序排序;延迟
bubuko.com,布布扣        /// OrderByDescending - 按指定表达式对集合倒序排序;延迟
bubuko.com,布布扣        /// </summary>
bubuko.com,布布扣        void Summary_OrderBy_OrderByDescending()
bubuko.com,布布扣        {
bubuko.com,布布扣                // 使用OrderBy查询操作符
bubuko.com,布布扣                var ary = (from a in _ary
bubuko.com,布布扣                                     select a).OrderBy(a => a.Length); // OrderByDescending与OrderBy用法相同
bubuko.com,布布扣
bubuko.com,布布扣                foreach (string s in ary)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += s + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                // 与上面的OrderBy查询操作符相对应的查询语法
bubuko.com,布布扣                var ary2 = from a in _ary
bubuko.com,布布扣                                     orderby a.Length ascending // orderby xxx descending与orderby xxx ascending用法相同
bubuko.com,布布扣                                     select a;
bubuko.com,布布扣
bubuko.com,布布扣                foreach (string s in ary2)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += s + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣        }
 
运行结果
wf
css
wcf
wpf
linq
ssis
ssas
ssrs
xhtml
csharp
asp.net
sqlserver
javascript
silverlight
asp.net ajax

GroupBy - 分组;延迟
/// <summary>
bubuko.com,布布扣        /// GroupBy - 分组;延迟
bubuko.com,布布扣        /// </summary>
bubuko.com,布布扣        void Summary_GroupBy()
bubuko.com,布布扣        {
bubuko.com,布布扣                // 使用GroupBy查询操作符
bubuko.com,布布扣                var list = (from a in _ary
bubuko.com,布布扣                                        select a).GroupBy(a => a.Length).Select(
bubuko.com,布布扣                                                g => new { Group = g.Key, Member = g });
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var g in list)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += g.Group + "个字符:<br />";
bubuko.com,布布扣
bubuko.com,布布扣                        foreach (string s in g.Member)
bubuko.com,布布扣                        {
bubuko.com,布布扣                                result.InnerHtml += "--" + s + "<br />";
bubuko.com,布布扣                        }
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                // 与上面的GroupBy查询操作符相对应的查询语法
bubuko.com,布布扣                var list2 = from a in _ary
bubuko.com,布布扣                                        group a by a.Length into g
bubuko.com,布布扣                                        select new { Group = g.Key, Member = g };
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var g in list2)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += g.Group + "个字符:<br />";
bubuko.com,布布扣
bubuko.com,布布扣                        foreach (string s in g.Member)
bubuko.com,布布扣                        {
bubuko.com,布布扣                                result.InnerHtml += "--" + s + "<br />";
bubuko.com,布布扣                        }
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣        }
 
 
运行结果
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>
bubuko.com,布布扣        /// Join - Join查询;延迟
bubuko.com,布布扣        /// </summary>
bubuko.com,布布扣        void Summary_Join()
bubuko.com,布布扣        {
bubuko.com,布布扣                // 使用Join查询操作符
bubuko.com,布布扣                var products = _ctx.Products.Join(
bubuko.com,布布扣                        _ctx.Categories,    
bubuko.com,布布扣                        p => p.CategoryID,    
bubuko.com,布布扣                        c => c.CategoryID,    
bubuko.com,布布扣                        (p, c) => new { c.CategoryName, p.ProductName }).Take(5);
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var p in products)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += p.CategoryName + " - " + p.ProductName + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                // 与上面的Join查询操作符相对应的查询语法
bubuko.com,布布扣                var products2 = (from p in _ctx.Products
bubuko.com,布布扣                                                 join c in _ctx.Categories
bubuko.com,布布扣                                                 on p.CategoryID equals c.CategoryID
bubuko.com,布布扣                                                 select new { c.CategoryName, p.ProductName }).Take(5);
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var p in products2)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += p.CategoryName + " - " + p.ProductName + "<br />";
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣        }
 
运行结果
Beverages - Chai
Beverages - Chang
Condiments - Aniseed Syrup
Condiments - Chef Anton‘s Cajun Seasoning
Condiments - Chef Anton‘s Gumbo Mix

GroupJoin - 分组Join查询;延迟
bubuko.com,布布扣 /// <summary>
bubuko.com,布布扣        /// GroupJoin - 分组Join查询;延迟
bubuko.com,布布扣        /// </summary>
bubuko.com,布布扣        void Summary_GroupJoin()
bubuko.com,布布扣        {
bubuko.com,布布扣                // 使用GroupJoin查询操作符
bubuko.com,布布扣                var products = _ctx.Categories.GroupJoin(
bubuko.com,布布扣                        _ctx.Products,    
bubuko.com,布布扣                        c => c.CategoryID,    
bubuko.com,布布扣                        p => p.CategoryID,    
bubuko.com,布布扣                        (p, g) => new { p.CategoryName, ProductCount = g.Count() });
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var g in products)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += g.CategoryName + ":" + g.ProductCount + "<br />";
bubuko.com,布布扣
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                // 与上面的GroupJoin查询操作符相对应的查询语法
bubuko.com,布布扣                var products2 = from c in _ctx.Categories
bubuko.com,布布扣                                                join p in _ctx.Products on c.CategoryID equals p.CategoryID into g
bubuko.com,布布扣                                                select new { CategoryName = c.CategoryName, ProductCount = g.Count() };
bubuko.com,布布扣
bubuko.com,布布扣
bubuko.com,布布扣                foreach (var g in products2)
bubuko.com,布布扣                {
bubuko.com,布布扣                        result.InnerHtml += g.CategoryName + ":" + g.ProductCount + "<br />";
bubuko.com,布布扣
bubuko.com,布布扣                }
bubuko.com,布布扣                result.InnerHtml += "<br />";
bubuko.com,布布扣        }
 
运行结果
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

标签:des   blog   http   io   os   使用   java   ar   for   

原文地址:http://www.cnblogs.com/DJYBlog/p/3972901.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!