LINQ巩固
LINQ巩固
- LINQ过滤运算符
Where 基于谓词函数过滤值
测试例子如下:
public class TestModel
{
public string Name { get; set; }
public string Age { get; set; }
}
List<TestModel> lst = new List<TestModel>()
{
new TestModel(){Name = "张三" },
new TestModel(){Name = "李四" },
};
var querys1 = from item in lst where item.Name == "李四" select item;
var querys2 = lst.Where(item => item.Name == "李四");
- LINQ Join操作
| !运算符 | 描述 | 查询语法 |
|---|---|---|
| Join | 运算符连接两个序列配键的基础 | join...in...on...equals... |
| GroupJoin | 连接连个序列和组匹配元素 | join...in...on...equals...into |
测试例子:
··· C#
List lst = new List()
{
new TestModel(){Name = "张三", Age = "23" },
new TestModel(){Name = "李四", Age = "43" },
};
List<CameraModel> lstCamera = new List<CameraModel>()
{
new CameraModel(){Name = "张三", Price = "sfsf" },
new CameraModel(){Name = "张三", Price = "测试工程时" },
new CameraModel(){Name = "李四", Price = "买菜的" }
};
var query = from it in lst
join item in lstCamera on it.Name equals item.Name
select new
{
it.Name,
it.Age,
item.Price
};
···
- LINQ投影操作
| 运算符 | 描述 |
|---|---|
| Select | 操作转换函数的基础项目值 |
| SelectMany | 操作项目的值是根据上的转换函数,以及拼合成一个单一的序列的序列 |
var querys = from ite in lst from item in lstCamera select ite;
- LINQ排序运算符
| 操作符 | 描述 |
|---|---|
| OrderBy | 按升序操作排序值 |
| OrderByDescending | 按降序排序操作值 |
| ThenBy | 执行二次元排序按升序 |
| ThenByDescending | 执行二次排序以降序 |
| Reverse | 进行反转的元素顺序 |
- LINQ分组操作
| 操作 | 描述 |
|---|---|
| GroupBy | 组织项目的顺序组,并将其返回IEnumerable类型的集合 |
| ToLookup | 执行在其中的密钥对的序列被返回分组运算 |
- LINQ转换操作
| 操作符 | 描述 |
|---|---|
| AsEnumerable | 返回输入类型为IEnumerable T |
| AsQueryable | IEnumerable被转换为IQueryable |
| Case | 执行一个集合的元素的转换到一个指定类型 |
| OfType | 在它们的基础上过滤值,这取决于它们的能力,以被转换为特定类型 |
| ToArray | 转换为数组 |
| ToDictionary | 转为字典 |
| ToList | 转为列表 |
| ToLookup | 强制执行查询,并把元素融入一个Lookup TKey,TElement键选择器函数 |
- LINE级联
| 操作符 | 描述 |
|---|---|
| Concat | 两个序列被连接为一个单一的一个序列 |
- LINQ聚合
| 操作 | 描述 |
|---|---|
| Aggergate | 对集合的值进行操作执行自定义聚合操作 |
| Average | 计算集合的平均值 |
| Count | 计算数量 |
| LongCount() | 计算一个巨大集合中的数量 |
| Max | 找出一个集合中的最大值 |
| Min | 找出一个最小值 |
| Sum | 计算总和 |
- LINQ量词操作
| 操作 | 描述 |
|---|---|
| All | 返回一个值'true',如果序列中的所有元素满足谓词条件 |
| Any | 确定通过搜索一个序列是否相同的任何元素满足规定条件 |
| Contains | 如果找到某个特定元素有一个序列返回一个'true'的值,如果序列不包含特定的元素,'false‘值返回 |
- LINQ分区操作符
| 操作 | 描述 |
|---|---|
| Skip | 跳过一些指定的序列中一些元素,并返回其余的 |
| SkipWhile | 相同,唯一的例外调到多个元素,跳过的是由一个布尔条件指定 |
| Take | 采取元素指定数量的序列,并跳过其余的 |
| TakeWhile | 相同,布尔条件指定 |
- LINQ元素操作符
| 操作 | 描述 |
|---|---|
| ElementAt | 返回一个特定的索引中的一个元素存在于一个集合 |
| ElementAtOrDefault | 相同与ElementAt,未找到返回默认值 |
| First | 检索集合的满足的第一个元素 |
| FirstOrDefault | 相同,未检索到返回默认值 |
| Last | 用法同上 |
| LastOrDefault | 同上 |
| Single | 返回集合唯一元素或唯一元素满足的一定条件 |
| SingleOrDefault | 不解释 |
LINQ巩固的更多相关文章
- Linq表达式、Lambda表达式你更喜欢哪个?
什么是Linq表达式?什么是Lambda表达式? 如图: 由此可见Linq表达式和Lambda表达式并没有什么可比性. 那与Lambda表达式相关的整条语句称作什么呢?在微软并没有给出官方的命名,在& ...
- Linq之旅:Linq入门详解(Linq to Objects)
示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...
- [C#] 走进 LINQ 的世界
走进 LINQ 的世界 序 在此之前曾发表过三篇关于 LINQ 的随笔: 进阶:<LINQ 标准查询操作概述>(强烈推荐) 技巧:<Linq To Objects - 如何操作字符串 ...
- [C#] 进阶 - LINQ 标准查询操作概述
LINQ 标准查询操作概述 序 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> ...
- LINQ to SQL语句(7)之Exists/In/Any/All/Contains
适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...
- .NET深入实战系列—Linq to Sql进阶
最近在写代码的过程中用到了Linq查询,在查找资料的过程中发现网上的资料千奇百怪,于是自己整理了一些关于Linq中容易让人困惑的地方. 本文全部代码基于:UserInfo与Class两个表,其中Cla ...
- LINQ Group By操作
在上篇文章 .NET应用程序与数据库交互的若干问题 这篇文章中,讨论了一个计算热门商圈的问题,现在在这里扩展一下,假设我们需要从两张表中统计出热门商圈,这两张表内容如下: 上表是所有政区,商圈中的餐饮 ...
- Entity Framework 6 Recipes 2nd Edition(11-9)译 -> 在LINQ中使用规范函数
11-9. 在LINQ中使用规范函数 问题 想在一个LINQ查询中使用规范函数 解决方案 假设我们已经有一个影片租赁(MovieRental )实体,它保存某个影片什么时候租出及还回来,以及滞纳金等, ...
- Entity Framework 6 Recipes 2nd Edition(11-11)译 -> 在LINQ中调用数据库函数
11-11. 在LINQ中调用数据库函数 问题 相要在一个LINQ 查询中调用数据库函数. 解决方案 假设有一个任命(Appointment )实体模型,如Figure 11-11.所示, 我们想要查 ...
- Entity Framework 6 Recipes 2nd Edition(13-6)译 -> 自动编译的LINQ查询
问题 你想为多次用到的查询提高性能,而且你不想添加额外的编码或配置. 解决方案 假设你有如Figure 13-8 所示的模型 Figure 13-8. A model with an Associat ...
随机推荐
- 【Leetcode】【Medium】Single Number II
Given an array of integers, every element appears three times except for one. Find that single one. ...
- WAKE-WIN10-SOFT-软件-Matlab配置及工具箱
1Matlab 1,1Matlab下载,安装,配置,,, 1,2 2工具箱 2,1LibSVM 必应:https://www.bing.com/search?q=libsvm&qs=n& ...
- TinkPHP去重统计查询
当统计一个有重复的字段可以用这个方法 $count = $model->where($map)->count('distinct(id)'); 转自 http://www.thinkphp ...
- 【luogu P2762 太空飞行计划问题】 题解
题目链接:https://www.luogu.org/problemnew/show/P2762 算是拍照那个题的加强下. 输入真的很毒瘤.(都这么说但好像我的过了?) #include <qu ...
- Android学习笔记_46_Android的intent之间Object、List、List<Object>和全局变量数据的传递(Parcelable Serializable)
转http://blog.csdn.net/pku_android/article/details/7456305 一.传递List<String>和List<Integer> ...
- FreeImage.lib库的配置和简单使用 转
转载地址 http://www.codeweblog.com/win8-1%E4%B8%8Bfreeimage-lib%E5%BA%93%E7%9A%84%E9%85%8D%E7%BD%AE%E5%9 ...
- 数据库——MySQL——多表查询
这里多表,为了方便我只建了两张表,更复杂的表间也就是这些东西,就是复杂程度不一样. 数据源准备 建立一个学生表,和一个班级表 # 建立学生表 create table student( id int ...
- 微信小程序已发布版本vconsole仍出现问题解决办法
解决办法很简单,进入小程序的体验或者开发版,点击关闭调试,再次进入小程序,就不会出现了
- 洛谷P3804 【模板】后缀自动机
题目描述 给定一个只包含小写字母的字符串 SS , 请你求出 SS 的所有出现次数不为 11 的子串的出现次数乘上该子串长度的最大值. 输入输出格式 输入格式: 一行一个仅包含小写字母的字符串 SS ...
- VMware ESXi-6.7——安装
前提条件: 下载ESXi-ISO镜像文件 制作启动文件 将服务器调试为U盘启动 进入U盘启动模式 1. 进入ESXi的安装页面 选择要安装的磁盘 选择USB口驱动 设置一个root密码 保存数据提示 ...