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. JSP中include动作与指令

    include指令 JSP中有三大指令:page,include,taglib,之前已经说过了page的用法.这里介绍下include. 使用语法如下: <%@ include file=&qu ...

  2. Ubuntu 12.04 安装Chrome步骤

    一.添加PPA 从Google Linux Repository(http://www.google.com/linuxrepositories/)下载安装Key,或把下面的代码复制进终端,回车,需要 ...

  3. JavaMail简单应用

    版权声明:本文为博主原创文章,未经博主同意不得转载. --caicongyang https://blog.csdn.net/caicongyang/article/details/33731395 ...

  4. [19/03/15-星期五] 常用类_String类&StringBuilder和StringBuffer类

    一.基本概念 String 类对象代表不可变的Unicode字符序列,因此我们可以将String对象称为“不可变对象”. 那什么叫做“不可变对象”呢?  指的是对象内部的成员变量的值无法再改变.Str ...

  5. python+requests实现接口测试 - get与post请求使用

    简介:Requests 是用Python语言编写,基于 urllib,采用 Apache2 Licensed 开源协议的 HTTP 库.它比 urllib 更加方便,可以节约我们大量的工作,完全满足 ...

  6. P2939 改造路

    P2939 [USACO09FEB]改造路Revamping Trails 裸地分层图最短路 培训的时候考到过 但是-- 我考试的时候写了个基本没有的树状数组优化.然后顺利的被卡到了70分(裸的spf ...

  7. AngularJS 使用 even 和 odd 表格

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  8. LeetCode4.寻找两个有序数组的中位数 JavaScript

    给定两个大小为 m 和 n 的有序数组 nums1 和 nums2. 请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n)). 你可以假设 nums1 和 nums2  ...

  9. Restframework中常见API的编写方式

    1.框架一(继承APIView) 这里的第一部分使用骨架请参考我的博客(第三篇),它采用了restframework中最基础的办法(APIView)实现了相关请求,以下的框架都是基于它的 2.框架二( ...

  10. TIDB3 —— 三篇文章了解 TiDB 技术内幕 - 说计算

    原文地址:https://pingcap.com/blog-cn/tidb-internal-2/ 关系模型到 Key-Value 模型的映射 在这我们将关系模型简单理解为 Table 和 SQL 语 ...