Linq有两种语法1方法语法2查询语法下面举个例子看看这两.doc_第1页
Linq有两种语法1方法语法2查询语法下面举个例子看看这两.doc_第2页
Linq有两种语法1方法语法2查询语法下面举个例子看看这两.doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、一、 Linq 有两种语法:1、 方法语法2、 查询语法下面举个例子看看这两种方法的区别比如现在有一个学生类publicclassstudentpublicstringusername get ; set ; publicint age get ; set; publicstringsex get ;set ; 我们通过一个方法来添加很多同学publicIList GetStu(intn)IListfor( stuList = int i = 0; i n; i+)new List ();studentstu =new student();stu.age = 25 + i;stu.sex =s

2、tu.username = 男 + i; 张三 + i;stuList.Add(stu);returnstuList;那么这个方法返回的就是一个list集合,下面我们就可以通过linq对这个集合进行操作首先我们来查询所有的学生A、查询语法:var list = GetStu(10);var result = from s in listselect new stuname=s.username,sex=s.sex,age=s.age;这是 linq常用的语法from变量 in集合Select变量B、方法语法var result1= list.Select(s1= new username =

3、s1.username,age = s1.age,sex = s1.sex );这就是方法语法,符合一般的C#语法这两种方法的执行结果是一样的,唯一的区别就是语法二、输出的方式输出的方式也有两种,我们知道 linq 主要对集合进行操作的,所以一般都需要循环输出第一种输出方式:stringstt =null ;foreach( var sain result3)stt += sa.username;Response.Write(stt);这是我们经常用到的foreach循环第二种输出方式:result.ToList().ForEach(s = Response.Write(s.stuname+s

4、.sex+s.age); );这种方式很简介,直接调用ForEach 方法,方法体内是一个limba 表达式另外说明下ToList()方法作用,在linq中有种延迟执行,就是当我们在fromselect时候,返回的结果并没有执行,当我们循环调用的时候才执行,这就是延迟执行,有时候为了立即执行,我们需要用到ToList()三、下面就来简单说说linq常用的几种查询1、条件选择查询(where)比如我们要查询年龄大于26 的学生,可以这样写var result =from sin listwhere s.age26/ 条件查询selects.username;或者这样写var result2 =

5、list.Where(s = s.age 25);/ 条件查询2、 查询排序比如我们要按照学生年龄倒序排列查询var result =from sin listorderbys.agedescending/ 排序where s.age26/ 条件查询selects.username;或者这样写var result3 = list.OrderByDescending(s1 =s1.age);3、 数据查询分页显示使用了 Skip 和 Take 方法Skip 作用跳过指定数量的元素Take 的作用是返回指定位置连续数量的元素var list1 = GetList(50);for( inti = 0; i Response.Write(s); );这就是分5 页,每页显示10 个的分页方式4|、返回单个元素用到 First() , FirstOrDefault(),single,singleOrDefault()First(): 返回第一个元素,如果没有,则抛出异常FirstOrDefault(): 返回第一个元素,如果没有,则返回空,一般情况下会返回Single: 返回的是元素中唯一的元素,如果小于一条,则抛出异常singleOrDefault: 返回的是元素中唯一的元素,如果小于一条,则返回空,通常是nullnullvar result1 =fro

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论