LINQ巩固

  1. 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 == "李四");
  1. 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

};

···

  1. LINQ投影操作
运算符 描述
Select 操作转换函数的基础项目值
SelectMany 操作项目的值是根据上的转换函数,以及拼合成一个单一的序列的序列
var querys = from ite in lst from item in lstCamera select ite;
  1. LINQ排序运算符
操作符 描述
OrderBy 按升序操作排序值
OrderByDescending 按降序排序操作值
ThenBy 执行二次元排序按升序
ThenByDescending 执行二次排序以降序
Reverse 进行反转的元素顺序
  1. LINQ分组操作
操作 描述
GroupBy 组织项目的顺序组,并将其返回IEnumerable类型的集合
ToLookup 执行在其中的密钥对的序列被返回分组运算
  1. LINQ转换操作
操作符 描述
AsEnumerable 返回输入类型为IEnumerable T
AsQueryable IEnumerable被转换为IQueryable
Case 执行一个集合的元素的转换到一个指定类型
OfType 在它们的基础上过滤值,这取决于它们的能力,以被转换为特定类型
ToArray 转换为数组
ToDictionary 转为字典
ToList 转为列表
ToLookup 强制执行查询,并把元素融入一个Lookup TKey,TElement键选择器函数
  1. LINE级联
操作符 描述
Concat 两个序列被连接为一个单一的一个序列
  1. LINQ聚合
操作 描述
Aggergate 对集合的值进行操作执行自定义聚合操作
Average 计算集合的平均值
Count 计算数量
LongCount() 计算一个巨大集合中的数量
Max 找出一个集合中的最大值
Min 找出一个最小值
Sum 计算总和
  1. LINQ量词操作
操作 描述
All 返回一个值'true',如果序列中的所有元素满足谓词条件
Any 确定通过搜索一个序列是否相同的任何元素满足规定条件
Contains 如果找到某个特定元素有一个序列返回一个'true'的值,如果序列不包含特定的元素,'false‘值返回
  1. LINQ分区操作符
操作 描述
Skip 跳过一些指定的序列中一些元素,并返回其余的
SkipWhile 相同,唯一的例外调到多个元素,跳过的是由一个布尔条件指定
Take 采取元素指定数量的序列,并跳过其余的
TakeWhile 相同,布尔条件指定
  1. LINQ元素操作符
操作 描述
ElementAt 返回一个特定的索引中的一个元素存在于一个集合
ElementAtOrDefault 相同与ElementAt,未找到返回默认值
First 检索集合的满足的第一个元素
FirstOrDefault 相同,未检索到返回默认值
Last 用法同上
LastOrDefault 同上
Single 返回集合唯一元素或唯一元素满足的一定条件
SingleOrDefault 不解释

LINQ巩固的更多相关文章

  1. Linq表达式、Lambda表达式你更喜欢哪个?

    什么是Linq表达式?什么是Lambda表达式? 如图: 由此可见Linq表达式和Lambda表达式并没有什么可比性. 那与Lambda表达式相关的整条语句称作什么呢?在微软并没有给出官方的命名,在& ...

  2. Linq之旅:Linq入门详解(Linq to Objects)

    示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...

  3. [C#] 走进 LINQ 的世界

    走进 LINQ 的世界 序 在此之前曾发表过三篇关于 LINQ 的随笔: 进阶:<LINQ 标准查询操作概述>(强烈推荐) 技巧:<Linq To Objects - 如何操作字符串 ...

  4. [C#] 进阶 - LINQ 标准查询操作概述

    LINQ 标准查询操作概述 序 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> ...

  5. LINQ to SQL语句(7)之Exists/In/Any/All/Contains

    适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...

  6. .NET深入实战系列—Linq to Sql进阶

    最近在写代码的过程中用到了Linq查询,在查找资料的过程中发现网上的资料千奇百怪,于是自己整理了一些关于Linq中容易让人困惑的地方. 本文全部代码基于:UserInfo与Class两个表,其中Cla ...

  7. LINQ Group By操作

    在上篇文章 .NET应用程序与数据库交互的若干问题 这篇文章中,讨论了一个计算热门商圈的问题,现在在这里扩展一下,假设我们需要从两张表中统计出热门商圈,这两张表内容如下: 上表是所有政区,商圈中的餐饮 ...

  8. Entity Framework 6 Recipes 2nd Edition(11-9)译 -> 在LINQ中使用规范函数

    11-9. 在LINQ中使用规范函数 问题 想在一个LINQ查询中使用规范函数 解决方案 假设我们已经有一个影片租赁(MovieRental )实体,它保存某个影片什么时候租出及还回来,以及滞纳金等, ...

  9. Entity Framework 6 Recipes 2nd Edition(11-11)译 -> 在LINQ中调用数据库函数

    11-11. 在LINQ中调用数据库函数 问题 相要在一个LINQ 查询中调用数据库函数. 解决方案 假设有一个任命(Appointment )实体模型,如Figure 11-11.所示, 我们想要查 ...

  10. Entity Framework 6 Recipes 2nd Edition(13-6)译 -> 自动编译的LINQ查询

    问题 你想为多次用到的查询提高性能,而且你不想添加额外的编码或配置. 解决方案 假设你有如Figure 13-8 所示的模型 Figure 13-8. A model with an Associat ...

随机推荐

  1. day008-File文件

    1. File 文件和目录路径名的抽象表示形式. 一个File类对象就代表了一个文件或文件夹. 1.1 File类的作用 用来操作硬盘上的文件或文件夹 绝对路径:一般是以盘符开始的,比如:C:/Jav ...

  2. HTML专题

    1. 在<form><form/>标签里面的<button>标签要设置type="button",否则可能会在点击按钮时自动提交这个表单 2. ...

  3. 推荐一个很好用的脚本session snapper

    源网址http://tech.e2sn.com/oracle-scripts-and-tools/session-snapper 内容: If you want to just download Sn ...

  4. March 13 2017 Week 11 Monday

    A warm smile is the universal language of kindness. 温暖的笑容是善意的通用语. Face comes from the heart. Just sm ...

  5. python入门16 递归函数 高阶函数

    递归函数:函数内部调用自身.(要注意跳出条件,否则会死循环) 高阶函数:函数的参数包含函数 递归函数 #coding:utf-8 #/usr/bin/python """ ...

  6. Java里面String的编码问题

    Java里面内置字符串全部是utf-16编码,详细的编码方式看这里 import java.nio.charset.Charset; import java.util.Arrays; import j ...

  7. bootstrap table 怎么实现前两列固定冻结?

    $("#Table").bootstrapTable('destroy').bootstrapTable({ pagination: true,//分页 minimumCountC ...

  8. HDU 3336 KMP

    题意:求每一个前缀,跟前缀相同的每个子串. 此题:网上很多都是假程序,不过也AC了,的确我测试几个案例之后的的确确是存在这个问题. 分析:每一个前缀,可以考虑KMP,f失配指针,如何求得它出现了多少次 ...

  9. php 的 number_format使用

    $num = 1.0258963147; // 1.0259 $num = number_format($num, 4, '.', ''); $num = number_format($num); $ ...

  10. java中equals以及==的用法(简单介绍)

    简单介绍 equals方法是java.lang.Object类的方法 有两种用法说明: 一.对于字符串变量来说,使用“==”和“equals()”方法比较字符串时,其比较方法不同. 1.“==”比较两 ...