一、环境准备

1、创建俩个包含集合的类MartialArtsMaster和Kongu

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace LINQ查询
{class MartialArtsMaster{public int Id { get; set; }public string Name { get; set; }public int Age { get; set; }public string Menpai { get; set; }public string Kongfu { get; set; }public int Level { get; set; }public override string ToString(){return string.Format("Id: {0}, Name: {1}, Age: {2}, Menpai: {3}, Kongfu: {4}, Level: {5}", Id, Name, Age, Menpai, Kongfu, Level);}}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace LINQ查询
{class Kongfu{public int Id { get; set; }public string Name { get; set; }public int Power { get; set; }public override string ToString(){return string.Format("Id: {0}, Name: {1}, Power: {2}", Id, Name, Power);}}
}

2、创建集合

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace LINQ查询
{class Program{static void Main(string[] args){List<MartialArtsMaster> Mam = new List<MartialArtsMaster>(){new MartialArtsMaster() {Id = 1, Name = "黄蓉", Age = 18, Menpai = "丐帮", Kongfu = "打狗棒法", Level = 9},new MartialArtsMaster() {Id = 2, Name = "洪七公", Age = 70, Menpai = "丐帮", Kongfu = "打狗棒法", Level = 10},new MartialArtsMaster() {Id = 3, Name = "郭靖", Age = 22, Menpai = "丐帮", Kongfu = "降龙十八掌", Level = 10},new MartialArtsMaster() {Id = 4, Name = "任我行", Age = 50, Menpai = "明教", Kongfu = "葵花宝典", Level = 1},new MartialArtsMaster() {Id = 5, Name = "东方不败", Age = 35, Menpai = "明教", Kongfu = "葵花宝典", Level = 10},new MartialArtsMaster() {Id = 6, Name = "林平之", Age = 23, Menpai = "华山", Kongfu = "葵花宝典", Level = 7},new MartialArtsMaster() {Id = 7, Name = "岳不群", Age = 50, Menpai = "华山", Kongfu = "葵花宝典", Level = 8},new MartialArtsMaster() {Id = 8, Name = "令狐冲", Age = 23, Menpai = "华山", Kongfu = "独孤九剑", Level = 10},new MartialArtsMaster() {Id = 9, Name = "梅超风", Age = 23, Menpai = "桃花岛", Kongfu = "九阴真经", Level = 8},new MartialArtsMaster() {Id = 10, Name = "黄药师", Age = 23, Menpai = "梅花岛", Kongfu = "弹指神通", Level = 10},new MartialArtsMaster() {Id = 11, Name = "风清扬", Age = 23, Menpai = "华山", Kongfu = "独孤九剑", Level = 10}};List<Kongfu> Kf = new List<Kongfu>() {new Kongfu() {Id = 1, Name = "打狗棒法", Power = 90},new Kongfu() {Id = 2, Name = "降龙十八掌", Power = 95},new Kongfu() {Id = 3, Name = "葵花宝典", Power = 100},new Kongfu() {Id = 4, Name = "独孤九剑", Power = 100},new Kongfu() {Id = 5, Name = "九阴真经", Power = 100},new Kongfu() {Id = 6, Name = "弹指神通", Power = 100}};

二、使用LINQ查询

1、标准写法

            var res = from m in Mamfrom k in Kfwhere m.Kongfu == k.Nameselect  m;//select new{mam = k, kf = k};

该查询从同时从Man和Kf中查询,即俩个集合互相遍历查询?where后面跟查询筛选条件,select 后面跟输出的集合。可以使用new 输出一个组合,如注释行所示。

2、单个集合查询的扩展写法

var res = Mam.Where(delegate (MartialArtsMaster m) { return m.Id > 5; });//使用匿名函数版本
var res = Mam.Where(a =>  a.Id > 5 );//使用Lambda版本

3、多个集合查询的扩展写法,看不懂不建议用!!!请用标准的多个集合查询写法!!!

     var res = Mam.SelectMany(m => Kf, (m, k) => new { master = m, kongfu = k }).Where(x => x.master.Kongfu == x.kongfu.Name);

三、LINQ查询时返回排序结果

标准写法

            var res = from m in Mam orderby m.Age, m.Level//可选单一或多个排序方式,优先级以第一个最高往后依次递减select m;

扩展写法

            var res = Mam.Where(m => m.Level > 1).OrderBy(m => m.Level).ThenBy(m=>m.Age);

四、JOIN连接查询

1、

            var res = from m in Mamjoin k in Kf on m.Kongfu equals k.Name //当m.Kongfu 中与 k.Name能匹配的m和k被保留下来//Man连接Kfwhere m.Level>8select new { mam = m, kongfu = k };

3、JOIN连接单个查询并分组

             var res = from m in Mamgroup m by m.Menpai into Gorderby G.Count()select new { cont = G.Count(), key = G.Key };

4、JOIN连接查询并分组

            var res = from k in Kfjoin m in Mam on k.Name equals m.Kongfu //k连接m 在on后面只能先写k再写minto g //将匹配结果保存到g集合完成分组操作orderby g.Count()select new { kongfu = k, conunt = g.Count() };

五、量词操作符Any 和 All

            bool i = Mam.Any(m => m.Menpai == "华山");//当集合中存在元素符合条件时返回truevar res = from m in Mamwhere m.Menpai == "华山"select m;bool n = res.All(m => m.Menpai == "华山");//当集合中所有元素符合条件时返回true

集合查询和查询结果处理相关推荐

  1. Oracle 语言分类 数据类型 数据类型转换 常用函数 集合操作 子查询

    SQL分类 SQL(Structure Query Language)语言是数据库的核心语言.SQL语言共分为四大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL.1 ...

  2. mysql 查询 集合_MySQL使用集合函数进行查询操作实例详解

    本文实例讲述了MySQL使用集合函数进行查询操作.分享给大家供大家参考,具体如下: COUNT函数 SELECT COUNT(*) AS cust_num from customers; SELECT ...

  3. mysql通过集合查询_MySQL使用集合函数进行查询操作实例详解

    本文实例讲述了MySQL使用集合函数进行查询操作.分享给大家供大家参考,具体如下: COUNT函数 SELECT COUNT(*) AS cust_num from customers; SELECT ...

  4. MySQL—运算符详解(算术、比较、逻辑、范围运算符与集合运算符 模糊查询 NULL值运算与null值判断 位运算符)

    MySQL--运算符详解 知识纲要 算术运算符 比较运算符 逻辑运算符 范围运算符与集合运算符 模糊查询 NULL值运算与null值判断 位运算符 1.算术运算符 加 减 乘 除 取余 div 也表示 ...

  5. mysql list集合查询_MyBatis 传入List集合作为条件查询数据

    使用的是SSM框架,数据库是MySQL,做查询的时候传入List集合,使用SQL语句的in方式查询数据 主要有两点问题:我的List集合是利用的另外一个语句查询出来的,传入参数是int类型,返回值是i ...

  6. python查询在查询_python 查询,子查询以及1对多查询

    1.添加数据: # 方法1:对象.save() book = Book(**kwargs) book.save() # 方法2:类.create(**kwargs) Book.create(**kwa ...

  7. oracle子查询子查询,Oracle 单行子查询和多行子查询

    --什么是单行子查询? --从子查询中返回一行结果的查询 select e.employee_id,e.last_name,e.salary from employees e where e.depa ...

  8. 关系数据库SQL之基本数据查询:子查询、分组查询、模糊查询

    前言 上一篇关系数据库常用SQL语句语法大全主要是关系型数据库大体结构,本文细说一下关系型数据库查询的SQL语法. 语法回顾 SELECT [ALL|DISTINCT] <目标列表达式>[ ...

  9. 实验5 数据查询--连接查询

    实验5 数据查询--连接查询 一.实验目的 1.熟悉等值联接查询的方法. 2.熟悉非等值联接查询的方法. 3.熟悉自身联接查询的方法. 4.熟悉外联接查询的方法. 5.熟悉复合条件联接的方法. 二.实 ...

  10. mongotemplate模糊查_java 中 mongodb的各种操作 模糊查询 精确查询 等等

    本意是想查查mongo数据库的int类型的like怎么查,但是好像没 解决这个问题. 精确查询:模糊查询:分页查询,每页多少:按某个字段排序(或升或降):查询数量:大于,小于,等于:且,或,某个字段不 ...

最新文章

  1. Error: Discrete value supplied to continuous scale
  2. poj 2482 Stars in Your Window (线段树扫描线)
  3. ImageMagick 拆分透明PNG 合并JPG和Alpha Mask
  4. JAVA项目实训struts2_JavaWeb学习:Struts2与Spring的IOC练习
  5. Redis 3.2.4配置文件翻译
  6. Linux 软件安装与卸载
  7. 政策频发,全国区块链应用不断涌现 | 产业区块链发展周报
  8. 如何将PPT中的图片无改变矢量图插入word中以及matlab矢量图插入word方法【每天一个小技巧】
  9. Windows Update 无法启用 拒绝访问
  10. dataworks 生成表血缘依赖
  11. 找不到设备 将计算机连接到USB打印机,打印机连接电脑没反应怎么办
  12. 【转】中国与华尔街不同的投行人生
  13. 上海计算机学业水平考试,上海信息科技学业水平考试复习资料整理——计算机系统.pdf...
  14. 从户外露营到登陆火星,火星玩家电核装备让太空黑科技成为现实
  15. 持久层的EAO颗粒封装
  16. comsol动网格(als)帮助文档翻译
  17. PTA 1032 挖掘机技术哪家强 (c语言)
  18. 自制Unity 色相环调色板
  19. linux下gperf工具(tcmalloc)检查C/C++代码内存泄露问题操作说明
  20. 麒麟系统下安装mysql_Ubuntu麒麟下安装MySQL+Django+Python(一)

热门文章

  1. Origin怎么画圆形而非椭圆形?
  2. OpenWrt之DNS域名解析系统(/etc/resolv.conf)
  3. 【CLR】程序集查找与GAC
  4. js正则表达式之match函数
  5. Ubuntu18.04安装ceres-solver
  6. 选票统计 SDUT
  7. GitHub 上有哪些考研神器?
  8. 计算机毕业设计SSM常见病辅助食疗系统【附源码数据库】
  9. 黄冈市2021高考成绩查询系统,黄冈师范学院
  10. Bundle-Adjustment并行求解器