惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
T
Threatpost
Latest news
Latest news
N
News | PayPal Newsroom
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Help Net Security
Help Net Security
D
Darknet – Hacking Tools, Hacker News & Cyber Security
AI
AI
Simon Willison's Weblog
Simon Willison's Weblog
TaoSecurity Blog
TaoSecurity Blog
The Last Watchdog
The Last Watchdog
L
LINUX DO - 热门话题
Google DeepMind News
Google DeepMind News
T
Threat Research - Cisco Blogs
O
OpenAI News
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
The Exploit Database - CXSecurity.com
NISL@THU
NISL@THU
Application and Cybersecurity Blog
Application and Cybersecurity Blog
S
Securelist
小众软件
小众软件
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Martin Fowler
Martin Fowler
S
SegmentFault 最新的问题
Cisco Talos Blog
Cisco Talos Blog
云风的 BLOG
云风的 BLOG
AWS News Blog
AWS News Blog
GbyAI
GbyAI
N
News and Events Feed by Topic
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
美团技术团队
Engineering at Meta
Engineering at Meta
A
About on SuperTechFans
博客园 - 三生石上(FineUI控件)
S
Schneier on Security
博客园 - 聂微东
V2EX - 技术
V2EX - 技术
T
Troy Hunt's Blog
SecWiki News
SecWiki News
S
Secure Thoughts
B
Blog RSS Feed
Hugging Face - Blog
Hugging Face - Blog
WordPress大学
WordPress大学
腾讯CDC
H
Heimdal Security Blog
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
Apple Machine Learning Research
Apple Machine Learning Research
月光博客
月光博客
www.infosecurity-magazine.com
www.infosecurity-magazine.com
P
Privacy International News Feed

博客园 - 稽首本然

Nhibernate 教程,有空看看 Jquery专题写的不少,有空看看,另该研究下门面模式了! Java开源权限管理中间件 《需求规格说明书》业务描述活动图 《需求规格说明书》(用例)陷阱 《需求规格说明书》核心功能表现方式(用例) LINQ TO SQL ScriptManager与UpdatePanel总结 Nunti测试工具使用整理 一个关于NHiberante,Linq数据源与UI交互引发的思考 数据库联接字符串 ASPX直接编写脚本function后使用javascript Aspx页面中直接编写javascript脚本 母版事件中注册javascript脚本 ASPNET跨页面传值技巧总结 javascript捣乱程序 Javascript在Asp.Net中的应用汇总 AjaxPanel中使用javascript AjaxPanel控件说明
LINQ TO OBJECT
稽首本然 · 2011-01-21 · via 博客园 - 稽首本然

LINQ .Net3.5提供的查询语言集合

源文http://www.tudou.com/programs/view/2I0rd1ql6js/

注意:

1必须创建.NET3.5环境的应用程序才可以使用,3.0也可以

2需要引入

using System.Linq;

using System.Data.Linq;

using System.Xml.Linq;

3C#对LINQ提供的支持

3.1 对象初始化器

           Student s=new Student();

          s.id=1;s.name="Jerry";

          //LINQ支持

          Student s=new {id=1,name="Jerry"};    // 对声明构造函数的简化,节省代码就是减少出错的机会。

3.2 隐式类型 var

          var 创建的对象是直接继承于Object的数据类型,强类型,可通过上下文进行定义的

    //形象的理解,var 是javascript的变量修饰符,而javascript变量是可以通过值,直接获得数据类型的,当然javascrip所有数据类型都是Ojbect类型,因此C#引入var是要使用javascript var类型的优点。

   //如: var s=new {id=1,name="Jerry"};  //我们可以访问s变量,甚至是方法。但无法知道s的类型。

   //如: var s=new {id=1;name="Jerry"};

                   Type type=s.getType();

                   Console.WriteLine(type.name);      //看看结果,一个运行时随即产生的名字

3.3 扩展静态方法

3.4 Lambda表达式

    是对匿名方法的改进 =>

4 LINQ常用操作

包括查询语法Lambda 表达式语法方式,只是在表现风格上有所不同

先定义一个类,便于使用

public class Student
    {
        public string id {get;set;}
        public double english {get;set;}
        public double computer {get;set;}
        public double math {get;set;}
        public double total { get {return english+computer+math; } }
        public double average { get { return total / 3; } }
    }

实例化之  //这对象的来源就多了,xml,webservice,数据库,业务逻辑,系统内存

var list = new List<Student>();
            Random r = new Random();
            for (int i = 0; i < 50; i++)
            {
                Student s = new Student();
                s.id = i.ToString("00");
                s.english = r.Next(0,100);
                s.math = r.Next(0, 100);
                s.computer = r.Next(0, 100);
                list.Add(s);
            }

4.1投影

针对数据库而言的一个概念

   如:统计平均成绩在60分以上的学生人数,不调用类的方法,只是模拟对结合的查询

    list.Count(g => (g.computer + g.english + g.math) / 3 >=60));

   //foreach (Student s in list)
         //{
         //    Console.WriteLine(s.computer);
         //}

4.2选择

    //var result = from ss in list
         
//      select new { ss.id, ss.total, ss.average };                     //匿名类型   
         
//var result = list.Select( ss => new { ss.id, ss.total, ss.average });//和上面等价

    //遍历
         
// list.ForEach(s => { Console.WriteLine("total:{0}", s.math + s.computer + s.english); });
         
// list.ForEach(s => { Console.WriteLine( s.math + s.computer + s.english); });

4.3排序

   //查询方式

     var result = from ss in list
                         orderby ss.average descending
                         select ss;

   //表达式方式

     var result = list.OrderByDescending(ss => ss.average);

    //查询平均成绩>60的学生ID
           /*
           var result = from ss in list where ss.average > 60 select ss;                  
           */
           //var result = list.Where(ss => ss.average >= 70);
           /*
           foreach (var s in result)
           {
               Console.WriteLine("id:{0},ave{1}", s.id, s.average);
           }

4.4数据分页 (这个太好了,在我还是初级程序员的时候,公司有个伪高人就是封装了分页存储过程的Web控件,然后如鱼得水了好一阵。做事情最好还是踏实点,觉得自己差不多了的时候,脑子里装不进新东西!)

Skip Take两个方法

     for (int i = 0; i < 5; i++)
            {
                Console.WriteLine("这是第:{0}页", i);
                Console.WriteLine("------------------------------------------------------------");
                var result = list.Skip(10).Take(10);
                foreach (var s in result)
                {
                    Console.WriteLine("id:{0}ave:{1}", s.id, s.average);
                }
                Console.WriteLine("------------------------------------------------------------");
            }

4.5返回单条记录

     //查找学生成绩大于90的第一名学生
           
var result = list.FirstOrDefault(s => s.math>90);
            if (result != null)
            {
                Console.WriteLine("id:{0}math:{1}",result.id,result.math.ToString("00.0"));
            }
            Console.ReadLine();  

    //知道 select top1 form user;吗?

    //那MSSql select DISTINCT name, * from user;呢?