linq基本操作
一、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()
上面只是简单的介绍了下linq的用法,具体项目中用到了,在具体对待
下载:/Files/shuang121/linq的基本操作.doc
linq基本操作的更多相关文章
- 一篇文章教你学会ASP.Net Core LINQ基本操作
一篇文章教你学会ASP.Net Core LINQ基本操作 为什么要使用LINQ LINQ中提供了很多集合的扩展方法,配合lambda能简化数据处理. 例如我们想要找出一个IEnumerable< ...
- C# LINQ 基本操作实例
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- Linq 基本操作
在linq中排序方法有: OrderBy() --对某列升序排序 ThenBy() --某列升序后对另一列后续升序排序 OrderByDescending() --对某列降序排序 ThenBy ...
- .NETCoreCSharp 中级篇2-3 Linq简介
.NETCoreCSharp 中级篇2-3 本节内容为Linq及其拓展方法.Linq中表达式树的使用 简介 语言集成查询(LINQ)是一系列直接将查询功能集成到C#语言的技术统称.数据查询历来都表示为 ...
- Linq查询基本操作
摘要:本文介绍Linq查询基本操作(查询关键字) - from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 ...
- C#中Linq查询基本操作
摘要:本文介绍Linq查询基本操作(查询关键字) - from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 ...
- Linq学习笔记四之linq to sql 的基本操作
首先需要在项目中新增一个 linq to sql 的服务 新增项,数据,LINQ TO sql 类的这个方法 第二步需要一个model类,用作映射 [Table] public class S_ZD ...
- linq to xml 基本操作
使用XDocument类来进行简单的xml操作,用于软件参数的设置保存. using System; using System.Collections.Generic; using System.Li ...
- Linq 查询基本操作
- from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 - let 子句 - 复合from子句 - 在某 ...
随机推荐
- 图像分类中max-pooling和average-pooling之间的异同
池化操作时在卷积神经网络中经常采用过的一个基本操作,一般在卷积层后面都会接一个池化操作,但是近些年比较主流的ImageNet上的分类算法模型都是使用的max-pooling,很少使用average-p ...
- Python 8 - Socket编程进阶
本节内容: 1.Socket语法及相关 2.SocketServer实现多并发 Socket语法及相关 socket 概念 socket本质上就是在2台网络互通的电脑之间架设一个通道,两台 ...
- 【tmos】如何在Interceptor拦截器中注入其他数据
光是这样是获取不到weixinConfig内容的 public class WebLoginInterceptor implements HandlerInterceptor { @Autowired ...
- 一看就懂——利用getJSON()与each()方法动态创建内容
一个案例——忘记的时候可以翻阅参考↓<务必放在服务器内才能看效果哟~> html文件内容如下↓ <!DOCTYPE html> <html> <head& ...
- Css - 字体图标
Css - 字体图标 字体格式 ttf.otf.woff.svg.eot 现在流行将图标做成矢量的字体格式的文档,很多用户在放大页面的时候页面上的普通图片格式的图标就会变得模糊不清,这种字体图标在网页 ...
- python 三大框架之一Flask入门
Flask轻量级框架,Flask是python中的轻量级框架. 打开终端 输入pip install Flask 命令 下载以及安装Flask框架 检查是否下载成功及能否使用 首先导入python环境 ...
- IntelliJ IDEA 配置
1.让IntelliJ IDEA 驼峰选择生效 驼峰选择,就是选择的时候按照驼峰规则选择单词,不是选择整个单词 让IntelliJ IDEA 驼峰选择生效 2.查看当前类中的所有方法 Alt+7 3. ...
- office 产品密钥
刚买的小新,配置下office,作为技术人员,喜欢Share以下 office 产品密钥,任你选一组 一.序列号激活法(密钥激活法)这种是最为安全而且最为正规的方法,通过取得合法的序列号(密钥)进行激 ...
- 【转】MySQL— 进阶
[转]MySQL— 进阶 目录 一.视图 二.触发器 三.函数 四.存储过程 五.事务 一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需 ...
- inception_v2版本《Rethinking the Inception Architecture for Computer Vision》(转载)
转载链接:https://www.jianshu.com/p/4e5b3e652639 Szegedy在2015年发表了论文Rethinking the Inception Architecture ...