LInq 与lambda表达式
LInq 与lambda表达式
LinQ是我们常用的技术之一。因为我们绕不开的要对数据进行一系列的调整,如 排序、 条件筛选、求和、分组、多表联接 等等。
lambda则是我们常用的语法糖,配合linq使用天衣无缝,不知不觉就用上了,主要还是看着代码简洁,逼格够高。。。
接下来我们就来看看常用的有哪些
先来点基础数据


//用户类
public class User
{
[DataMember]
public int ID { get; set; }
[DataMember]
public string Name { get; set; }
[DataMember]
public string Address { get; set; }
[DataMember]
public string Phone { get; set; }
[DataMember]
public string Sex { get; set; } [DataMember]
public int Age { get; set; }
[DataMember]
public int SchID { get; set; }
}

/// <summary>
/// 学校类
/// </summary>
internal class School {
public int SchID { get; set; }
public string SchName { get; set; }
public School(){}
public School(int id,string name)
{
SchID = id;
SchName = name;
}
}
/// <summary>
/// 公司类
/// </summary>
internal class Company {
public string Name { get; set; }
public List<User> Users { get; set; }
public Company() { }
public Company(string name, List<User> list)
{
Name = name;
Users = list;
}
}

接下来初始化点测试数据

User user1 = new User()
{
ID = 111,
Name = "张一",
Address = "上海市某某区",
Phone = "13547878787",
Age = 30,
Sex = "男",
SchID=1
};
User user2 = new User()
{
ID = 112,
Name = "李小二",
Address = "上海市某某区",
Phone = "13547878783",
Age = 30,
Sex = "女",
SchID = 1
};
User user3 = new User()
{
ID = 113,
Name = "张三",
Address = "上海市某某区",
Phone = "13547878784",
Age = 30,
Sex = "男",
SchID = 1
};
User user4 = new User()
{
ID = 114,
Name = "李四",
Address = "上海市某某区",
Phone = "13547878785",
Age = 30,
Sex = "男",
SchID = 1
};
List<User> userlist = new List<User>(4) { user1, user2, user3, user4 };
List<School> Schlist = new List<School>() {
new School(1,"武汉大学"),new School(2,"华中科技大学"),new School(3,"华中师范大学")
};

统计(求和)Sum

//求和
var sum = userlist.Where(a => { return a.ID > 0; }).Sum(a=>a.ID);
Console.WriteLine(sum);
//另一种写法
sum =(from a in userlist where a.ID>0 select a.ID ).Sum();
Console.WriteLine(sum);
IEnumerable.Where()方法里面的参数数委托类型Func<TSource, bool> 前面为参数 最后面一个为返回值

求最大最小值 Max Min
//求最大值
var max = userlist.Max(a => a.ID);
Console.WriteLine(max);
//最小值
var min = userlist.Min(a => a.ID);
Console.WriteLine(min);
循环 ForEach

//循环输出
userlist.ForEach(a =>
{
if (a.Age > 20)
{
Console.WriteLine(a.ID);
} });

条件筛选 where
//筛选
var user = userlist.Where(a => a.ID == 114).Single();
//筛选所有男性用户
var templist = userlist.Where(a => a.Sex == "男").ToList();
排序
//排序 根据ID逆序
templist = userlist.OrderByDescending(a => a.ID).ToList();
//升序
templist = userlist.OrderBy(a => a.ID).ToList();
分组 ToLookup 和 GroupBy

//分组
var lookup = userlist.ToLookup(a => a.Sex);
foreach (var item in lookup)
{
Console.WriteLine(item.Key);
foreach (var sub in item)
{
Console.WriteLine("\t\t"+sub.Name+" "+sub.Age);
}
}
//另一种
var dic = userlist.GroupBy(a => a.Sex);
foreach (var item in dic)
{
Console.WriteLine(item.Key);
foreach (var sub in item)
{
Console.WriteLine("\t\t" + sub.Name + " " + sub.Age);
}
}


联接 (这里只展示内联接)Join
//联接
var temp = from usertemp in userlist join sch in Schlist on usertemp.SchID equals sch.SchID
select new { Id = usertemp.ID, Name = usertemp.Name, Age = usertemp.Age,Schname=sch.SchName };
返回的匿名类,也可以指点实体类
类型查找 OfType
类型查找很少用到 因为我们都是用的泛型,不过这里还是列出来看看

//类型查找
List<object>objlist =new List<object>(){1,"2",false,"s",new User(){ID=1,Name="xx"}}; IEnumerable<string> query1 = objlist.OfType<string>(); foreach (string fruit in query1)
{
Console.WriteLine(fruit);
}


可以看到把2个字符串类型给查找出来了
查找深层嵌套 SelectMany
selectMany很少人用也比较少人知道,它可以避免多层嵌套循环 其使用场景还是挺多的,见下代码

//查找深层嵌套
//初始化数据 Company ChinaMobile = new Company("中国移动",userlist);
Company ChinaUnicom = new Company("中国联通", userlist);
List<Company> companylist = new List<Company>() { ChinaMobile, ChinaUnicom };
//找出2个公司所有女性成员
var selectlist = companylist.SelectMany(a => a.Users).Where(b => b.Sex == "女");
foreach (var item in selectlist)
{
Console.WriteLine(item.Name+":"+item.Sex);
}

这里可以看到 给出的数据源都是同一个list集合 然后我们看每个集合中只有一个女性成员


正常情况下要想取得这数据的话 要经过2层嵌套循环

foreach (Company c in companylist)
{ foreach (var item in c.Users)
{
if (item.Sex == "女")
{
Console.WriteLine(item.Name + ":" + item.Sex);
}
}
}


LInq 与lambda表达式的更多相关文章
- 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象
		
本文需要对C#里的LINQ.Lambda 表达式 .委托有一定了解. 在工作中,经常遇到需要对比两个集合的场景,如: 页面集合数据修改,需要保存到数据库 全量同步上游数据到本系统数据库 在这些场景中, ...
 - SQL、Linq和Lambda表达式 的关系
		
首先说说这三者完全是三种不同的东西,SQL是结构化查询语言(Structured Query Language)简称,这大家再熟悉不过了,下面主要介绍LINQ和Lambda表达式的基本概念以及同一查询 ...
 - c#封装DBHelper类  c# 图片加水印  (摘)C#生成随机数的三种方法  使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象  c# 制作正方形图片  JavaScript 事件循环及异步原理(完全指北)
		
c#封装DBHelper类 public enum EffentNextType { /// <summary> /// 对其他语句无任何影响 /// </summary> ...
 - 动态LINQ(Lambda表达式)构建
		
using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; us ...
 - LINQ使用Lambda表达式选择几列
		
学习LINQ的Lambda的表达式,尝试从数据集合中,选择其中几列. 创建一个model: source code: namespace Insus.NET.Models { public class ...
 - Linq之Lambda表达式
		
一 什么是LINQ? LINQ即Language Integrated Query(语言集成查询),LINQ是集成到C#和Visual Basic.NET这些语言中用于提供查询数据能力的一个新特性. ...
 - Linq之Lambda表达式初步认识
		
目录 写在前面 匿名方法 一个例子 Lambda 定义 一个例子 总结 参考文章 写在前面 元旦三天在家闲着无事,就看了看Linq的相关内容,也准备系统的学习一下,作为学习Linq的前奏,还是先得说说 ...
 - 【2017-06-01】Linq基础+Lambda表达式实现对数据库的增删改查
		
一.Linq to sql 类 高集成化的数据库访问技术 使用Linq可以代替之前的Ado.Net.省去了自己敲代码的实体类和数据访问类的大量工作. 实体类: 添加一个Linq to sql 类 -- ...
 - Linq基础+Lambda表达式对数据库的增删改及简单查询
		
一.Linq to sql 类 高集成化的数据库访问技术 使用Linq可以代替之前的Ado.Net,省去了自己敲代码的实体类和数据访问类的大量工作 实体类: 添加一个Linq to sql 类 --- ...
 
随机推荐
- Very Deep Convolutional Networks for Large-Scale Image Recognition
			
Very Deep Convolutional Networks for Large-Scale Image Recognition 转载请注明:http://blog.csdn.net/stdcou ...
 - Cocos2d-x 地图步行实现1:图论Dijkstra算法
			
下一节<Cocos2d-x 地图行走的实现2:SPFA算法>: http://blog.csdn.net/stevenkylelee/article/details/38440663 本文 ...
 - Angularjs 基于karma和jasmine的单元测试
			
目录: 1. 单元测试的配置 2. 实例文件目录解释 3. 测试controller 3.1 测试controller中变量值是否正确 3.2 模拟http请求返回值,测试$http服 ...
 - 递归遍历XML所有节点
			
package xml; import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.DocumentEx ...
 - 重新想象 Windows 8 Store Apps (17) - 控件基础: Measure, Arrange, GeneralTransform, VisualTree
			
原文:重新想象 Windows 8 Store Apps (17) - 控件基础: Measure, Arrange, GeneralTransform, VisualTree [源码下载] 重新想象 ...
 - Eclipse+Maven创建webapp项目<一> (转)
			
Eclipse+Maven创建webapp项目<一> 1.开启eclipse,右键new——>other,如下图找到maven project 2.选择maven project,显 ...
 - ios在SQLite3基本操作
			
iOS关于sqlite3操作 iPhone中支持通过sqlite3来訪问iPhone本地的数据库. 详细用法例如以下 1:加入开发包libsqlite3.0.dylib 首先是设置项目文件.在项目中加 ...
 - DP:树DP
			
The more, The Better Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
 - Java获得正则表达式
			
t='+escape(d.title)+'&u='+escape(d.location.href)+'&c='+escape(t),'keyit','scrollbars=no,wid ...
 - Android_使用StrictMode
调试开发
			
本博文为子墨原创,转载请注明出处! http://blog.csdn.net/zimo2013/article/details/40076049 1.StrictMode简单介绍 自Android 2 ...