linq和lambda基本操作

一、Linq有两种语法:

1、 方法语法

2、 查询语法

下面举个例子看看这两种方法的区别

比如现在有一个学生类

public class student

{

public string username { get; set; }

public int age { get; set; }

public string sex { get; set; }

}

我们通过一个方法来添加很多同学

public IList<student> GetStu(int n)

{

IList<student> stuList = new List<student>();

for (int i = 0; i < n; i++)

{

student stu = new student();

stu.age = 25 + i;

stu.sex = "男" + i;

stu.username = "张三" + i;

stuList.Add(stu);

}

return stuList;

}

那么这个方法返回的就是一个list集合,下面我们就可以通过linq对这个集合进行操作

首先我们来查询所有的学生

A、查询语法:

var list = GetStu(10);

var result = from s in list

select new { stuname=s.username,sex=s.sex,age=s.age};

这是linq常用的语法from 变量 in 集合

Select 变量

B、方法语法

var result1 = list.Select(s1 => new { username = s1.username, age = s1.age, sex = s1.sex });

这就是方法语法,符合一般的C#语法

这两种方法的执行结果是一样的,唯一的区别就是语法

二、输出的方式

输出的方式也有两种,我们知道linq主要对集合进行操作的,所以一般都需要循环输出

第一种输出方式:

string stt = null;

foreach (var sa in result3)

{

stt += sa.username;

}

Response.Write(stt);

这是我们经常用到的foreach循环

第二种输出方式:

result.ToList().ForEach(s => { Response.Write(s.stuname+s.sex+s.age); });

这种方式很简介,直接调用ForEach方法,方法体内是一个limba表达式

另外说明下ToList()方法作用,在linq中有种延迟执行,就是当我们在from…select时候,返回的结果并没有执行,当我们循环调用的时候才执行,这就是延迟执行,有时候为了立即执行,我们需要用到ToList()

三、下面就来简单说说linq常用的几种查询

1、条件选择查询(where)

比如我们要查询年龄大于26的学生,可以这样写

var result = from s in list

where s.age>26 //条件查询

select s.username;

或者这样写

var result2 = list.Where(s => s.age > 25); //条件查询

2、 查询排序

比如我们要按照学生年龄倒序排列查询

var result = from s in list

orderby s.age descending //排序

where s.age>26 //条件查询

select s.username;

或者这样写

var result3 = list.OrderByDescending(s1 =>s1.age);

3、 数据查询分页显示

使用了Skip和Take方法

Skip作用跳过指定数量的元素

Take的作用是返回指定位置连续数量的元素

var list1 = GetList(50);

for (int i = 0; i < 5; i++)

{

Response.Write("这是第" + (i + 1) + "页");

var result = from s in list.Skip(i * 10).Take(10)

select s;

result.ToList().ForEach(s => { Response.Write(s); });

}

这就是分5页,每页显示10个的分页方式

4|、返回单个元素

用到First(),FirstOrDefault(),single,singleOrDefault()

First():返回第一个元素,如果没有,则抛出异常

FirstOrDefault():返回第一个元素,如果没有,则返回空,一般情况下会返回null

Single:返回的是元素中唯一的元素,如果小于一条,则抛出异常

singleOrDefault:返回的是元素中唯一的元素,如果小于一条,则返回空,通常是null

var result1 = from r in list1

select r;

var rt = result1.First();

result1.Single()

转自http://blog.163.com/[email protected]/blog/static/782378472012102841026964/

时间: 2024-08-03 07:10:33

linq和lambda基本操作的相关文章

Linq之Lambda进阶

目录 写在前面 系列文章 带有标准查询运算符的Lambda Lambda中类型推断 Lambda表达式中变量作用域 异步Lambda 总结 写在前面 上篇文章介绍了Lambda的基本概念以及匿名方法,本篇继续介绍Lambda的一些内容,既然学了,就要总结的全面一点. 系列文章 Linq之Lambda表达式初步认识 带有标准查询运算符的Lambda 什么事标准查询运算符? “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法. 大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实

LINQ、Lambda与委托

首先定义个Person类: 1 public class Person 2 { 3 public string Name{get;set;} //姓名 4 public int Age{get;set;} //年龄 5 } 定义好List,并添加几条数据: 1 List<Person> lstPerson=new List<Person>(); 2 3 lstPerson.Add(new Person(){Name="Amy",Age=16}); 4 5 lst

通过16道练习学习Linq和Lambda

1. 查询Student表中的所有记录的Sname.Ssex和Class列.select sname,ssex,class from studentLinq:    from s in Students    select new {        s.SNAME,        s.SSEX,        s.CLASS    }Lambda:    Students.Select( s => new {        SNAME = s.SNAME,SSEX = s.SSEX,CLASS 

SQL、LINQ和Lambda表达式

首先说说这三者完全是三种不同的东西,SQL是结构化查询语言(Structured Query Language)简称,这大家再熟悉不过了,下面主要介绍LINQ和Lambda表达式的基本概念以及同一查询这三者的不同实现. 简单介绍 LINQ(Language Integrate Query)是语言集成查询他在对象和数据之间建立一种对应的关系,可以使用访问内存对象的方式查询数据集合.LINQ查询是C#中的一种语言构造.因此开发人员可以再C#代码汇总嵌套类似于SQL语句的查询表达式,从而实现数据查询的

linq,sql,lambda转换工具(推荐新手,初学者多多使用)

http://files.cnblogs.com/CielWater/Linqer.rar Linqer用于将sql语句转换为linq语句(暂不支持多表连接查询) http://files.cnblogs.com/CielWater/LINQPad4.zip LinqPad用于将linq语句转换为sql.lambda语句 linq,sql,lambda转换工具(推荐新手,初学者多多使用),布布扣,bubuko.com

SQL、LINQ、Lambda 三种用法(转)

SQL.LINQ.Lambda 三种用法 颜色注释: SQL LinqToSql Lambda QA 1. 查询Student表中的所有记录的Sname.Ssex和Class列. select sname,ssex,class from student Linq: from s in Students select new { s.SNAME, s.SSEX, s.CLASS } Lambda: Students.Select( s => new { SNAME = s.SNAME,SSEX =

Linq语法详细(三种方式:linq、Lambda、SQL语法)

三种方式:linq.Lambda.SQL语法 1.简单的linq语法 //1 var ss = from r in db.Am_recProScheme select r; //2 var ss1 = db.Am_recProScheme; //3 string sssql = "select * from Am_recProScheme"; 2.带where的查询 //1 var ss = from r in db.Am_recProScheme where r.rpId >

SQL、LINQ、Lambda 三种用法互换

SQL.LINQ.Lambda 三种用法颜色注释: SQL LinqToSql Lambda QA1. 查询Student表中的所有记录的Sname.Ssex和Class列.select sname,ssex,class from studentLinq: from s in Students select new { s.SNAME, s.SSEX, s.CLASS }Lambda: Students.Select( s => new { SNAME = s.SNAME,SSEX = s.SS

C#知识体系(一) --- 常用的LInq 与lambda表达式

LinQ是我们常用的技术之一.因为我们绕不开的要对数据进行一系列的调整,如 排序. 条件筛选.求和.分组.多表联接 等等. lambda则是我们常用的语法糖,配合linq使用天衣无缝,不知不觉就用上了,主要还是看着代码简洁,逼格够高... 接下来我们就来看看常用的有哪些 先来点基础数据 //用户类 public class User { [DataMember] public int ID { get; set; } [DataMember] public string Name { get;