Linq入门演练---(1)基本用法-分组,排序,内连接
这一节大家共同学习下LINQ的基本用法,主要包括LINQ的分组,排序,和内外连接。
1.分组
基本语法: group element by key
element 表示查询结果返回的元素,key表示分组条件。group子句返回的类型为IGrouping<TKey,TElement>的查询结果。
IGrouping<TKey,TElement>可以看成一个hashtable内部嵌套一个list列表的数据结果. 其中TElement就是一个list
我们看下面的一个事例,下面这个实例演示根据性别对用户进行分组
代码
- publicclass User
- {
- public User(string userName,string sex,int age)
- {
- UserName = userName;
- Sex = sex;
- Age = age;
- }
- publicstring UserName
- {
- get;
- set;
- }
- publicstring Sex
- {
- get;
- set;
- }
- publicint Age
- {
- get;
- set;
- }
- }
public class User
{
public User(string userName,string sex,int age)
{
UserName = userName;
Sex = sex;
Age = age;
} public string UserName
{
get;
set;
} public string Sex
{
get;
set;
} public int Age
{
get;
set;
}
}
- privatevoid button1_Click(object sender, EventArgs e)
- {
- User[] users = {
- new User("刘德华","男",40),
- new User("张学友","男",30),
- new User("张曼玉","女",35),
- new User("杨幂","女",53)
- };
- var query1 =
- from var1 in users
- group var1 by var1.Sex;
- string str = "";
- foreach (var item in query1)
- {
- str += item.Key + "\r\n";
- foreach (var user in item)
- {
- str += user.UserName + "--" + user.Sex + "--" + user.Age.ToString() + "\r\n";
- }
- }
- textBox1.Text = str;
- }
private void button1_Click(object sender, EventArgs e)
{
User[] users = {
new User("刘德华","男",40),
new User("张学友","男",30),
new User("张曼玉","女",35),
new User("杨幂","女",53)
}; var query1 =
from var1 in users
group var1 by var1.Sex; string str = "";
foreach (var item in query1)
{
str += item.Key + "\r\n"; foreach (var user in item)
{
str += user.UserName + "--" + user.Sex + "--" + user.Age.ToString() + "\r\n";
} }
textBox1.Text = str; }
效果图

以上是简单的分组,如果需要对分组结果进行排序,需要把分组结果保存到一个临时变量中
语法: group element by key into temp
以下是按年龄从小到大的排序:
代码
- User[] users = {
- new User("刘德华","男",40),
- new User("张学友","男",30),
- new User("张曼玉","女",35),
- new User("杨幂","女",53)
- };
- var query1 =
- from var1 in users
- group var1 by var1.Age into temp
- orderby temp.Key descending
- select temp;
- string str = "";
- foreach (var item in query1)
- {
- str += item.Key + "\r\n";
- foreach (var user in item)
- {
- str += user.UserName + "--" + user.Sex + "--" + user.Age.ToString() + "\r\n";
- }
- }
- textBox1.Text = str;
User[] users = {
new User("刘德华","男",40),
new User("张学友","男",30),
new User("张曼玉","女",35),
new User("杨幂","女",53)
};
var query1 =
from var1 in users
group var1 by var1.Age into temp
orderby temp.Key descending
select temp;
string str = "";
foreach (var item in query1)
{
str += item.Key + "\r\n";
foreach (var user in item)
{
str += user.UserName + "--" + user.Sex + "--" + user.Age.ToString() + "\r\n";
}
}
textBox1.Text = str;
效果图

2.排序
在linq中排序使用orderby
语法 orderby elment descending||ascending
ascending表示升序,descending表示降序
下面这个DEMO演示按年龄从大到小排序
代码:
- User[] users = {
- new User("刘德华","男",40),
- new User("张学友","男",30),
- new User("张曼玉","女",35),
- new User("杨幂","女",53)
- };
- var query1 =
- from var1 in users
- orderby var1.Age descending
- select var1;
- string str = "";
- foreach (var item in query1)
- {
- str += item.UserName + "--" + item.Age + "\r\n";
- }
- textBox1.Text = str;
User[] users = {
new User("刘德华","男",40),
new User("张学友","男",30),
new User("张曼玉","女",35),
new User("杨幂","女",53)
};
var query1 =
from var1 in users
orderby var1.Age descending
select var1;
string str = "";
foreach (var item in query1)
{
str += item.UserName + "--" + item.Age + "\r\n";
}
textBox1.Text = str;
效果图

3.内连接
内连接查询就是根据一定的条件查询两个数据源中都存在的元素
语法: join elment in datasource on re1 equals re2
以下代码查找两个数组中都存在的元素。
代码:
- privatevoid button3_Click(object sender, EventArgs e)
- {
- //查询两个数组中都存在的元素
- int[] arrOne = { 10,20,30,6,8};
- int[] arrTwo = { 10,4,6,8,90,3};
- var query = from re1 in arrOne
- join re2 in arrTwo on re1 equals re2
- select new { re1 = re1, re2 = re2 };
- foreach (var item in query)
- {
- Console.WriteLine(item);
- }
- }
private void button3_Click(object sender, EventArgs e)
{
//查询两个数组中都存在的元素
int[] arrOne = { 10,20,30,6,8};
int[] arrTwo = { 10,4,6,8,90,3}; var query = from re1 in arrOne
join re2 in arrTwo on re1 equals re2
select new { re1 = re1, re2 = re2 }; foreach (var item in query)
{
Console.WriteLine(item);
} }
查询结果:
- { re1 = 10, re2 = 10 }
- { re1 = 6, re2 = 6 }
- { re1 = 8, re2 = 8 }
{ re1 = 10, re2 = 10 }
{ re1 = 6, re2 = 6 }
{ re1 = 8, re2 = 8 }
4.左连接
左连接和SQL中的左连接类似,返回第一个结果集中的所有元素。
下面的代码演示使用左连接,左连接要用到defaultempty()方法,此方法从列表中获取指定元素,如果列表为空,返回默认值
代码
- privatevoid button4_Click(object sender, EventArgs e)
- {
- //左连接
- int[] arrOne = { 10, 20, 30, 6, 8 };
- int[] arrTwo = { 10, 4, 6, 8, 90, 3 };
- var query = from re1 in arrOne
- join re2 in arrTwo on re1 equals re2 into temgrp
- from grp in temgrp.DefaultIfEmpty()
- select new { re1 = re1, re2 = grp };
- foreach (var item in query)
- {
- Console.WriteLine(item);
- }
- }
private void button4_Click(object sender, EventArgs e)
{
//左连接
int[] arrOne = { 10, 20, 30, 6, 8 };
int[] arrTwo = { 10, 4, 6, 8, 90, 3 }; var query = from re1 in arrOne
join re2 in arrTwo on re1 equals re2 into temgrp
from grp in temgrp.DefaultIfEmpty()
select new { re1 = re1, re2 = grp }; foreach (var item in query)
{
Console.WriteLine(item);
}
}
查询结果
- { re1 = 10, re2 = 10 }
- { re1 = 20, re2 = 0 }
- { re1 = 30, re2 = 0 }
- { re1 = 6, re2 = 6 }
- { re1 = 8, re2 = 8 }
Linq入门演练---(1)基本用法-分组,排序,内连接的更多相关文章
- row_number() over (partition by....order by...)用法 分组排序
row_number() over (partition by....order by...)用法 分组排序 row_number() OVER (PARTITION BY COL1 ORDER BY ...
- Linq入门演练---(2)lambda表达式
今天大家一同学习下lambda表达式, lambda表达式使用起来更方便, lambda表达式其实是一个匿名函数,使用的运算符为=> 语法: (参数)=>表达式 如果只有一个参数,可以不使 ...
- oracle中分组排序函数用法 - 转
项目开发中,我们有时会碰到需要分组排序来解决问题的情况,如:1.要求取出按field1分组后,并在每组中按照field2排序:2.亦或更加要求取出1中已经分组排序好的前多少行的数据 这里通过一张表的示 ...
- ROW_NUMBER() OVER()函数用法;(分组,排序),partition by
转载:https://www.cnblogs.com/alsf/p/6344197.html 1.row_number() over()排序功能: (1) row_number() over()分组排 ...
- ROW_NUMBER() OVER()函数用法;(分组,排序),partition by (转)
1.row_number() over()排序功能: (1) row_number() over()分组排序功能: 在使用 row_number() over()函数时候,over()里头的分组以及排 ...
- Linq之旅:Linq入门详解(Linq to Objects)
示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...
- .Net进阶系列(4)-Lambda和linq入门(被替换)
一. Lambda和linq入门 lambda表达式又叫点标记,linq表达式又叫查询表达式,下面有三个简单的案例说明一下二者的基本用法,详细用法会在后续章节中更新. 二. 事例 1. 准备学生信息. ...
- LINQ入门教程之各种标准查询操作符(一)
好久之前就想系统的学习下LINQ,好久之前…… 本篇文章主要介绍LINQ等的标准查询操作符,内容取自<LINQ高级编程>,后续还会介绍LINQ to XML ,LINQ to SQL. L ...
- Linq之旅:Linq入门详解(Linq to Objects)【转】
http://www.cnblogs.com/heyuquan/p/Linq-to-Objects.html Linq之旅:Linq入门详解(Linq to Objects) 示例代码下载:Linq之 ...
随机推荐
- 程序员联盟有自己的论坛啦!基于Discuz构建,还不来注册~
我把程序员联盟网站的论坛建好了,哈哈哈.用的是Discuz这个腾讯旗下的中文bbs建设软件.正在完善论坛,添加各种模块和应用.大家可以先去注册一下:coderunity.com/bbs/forum.p ...
- 乐在其中设计模式(C#) - 桥接模式(Bridge Pattern)
原文:乐在其中设计模式(C#) - 桥接模式(Bridge Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 桥接模式(Bridge Pattern) 作者:webabcd 介绍 ...
- MongoDB学习笔记-维护
主从复制 MongoDB有主从复制技术,解决高可用和容灾问题,也就是备份. 配置主从的特点: N 个节点的集群 任何节点可作为主节点 所有写入操作都在主节点上 自动故障转移 自动恢复 数据分布式存储 ...
- 使用GDB在远程开发机上调试
由于一些环境限制,很多学生很可能需要在开发机器上调试.但是,由于对计算机资源的开发限制.在本地的直接机的发展GDB环境配置问题已经成为,其实,我们可以利用这段时间GDB自带gdbserver工具将能够 ...
- 探索WebKit核心(一)------ 新秀开始
为什么WebKit 现在,研究人员WebKit越来越多的人,我不能逃脱,其中还增加.WebKit也多亏了流行的浏览器和WebOS乱斗.随着Palm WebOS, Chrome OS, Firefox ...
- 【原版的】Redis事件驱动内核
Redis事件驱动内核 作者:cf (360电商技术组) 概述 Redis实现了自己的事件驱动,与开源事件库libevent.libev一样,都是基于I/O多路复用技术实现的.出于性能和代码精炼双方面 ...
- Jsoup一个简短的引论——采用Java抓取网页数据
转载请注明出处:http://blog.csdn.net/allen315410/article/details/40115479 概述 jsoup 是一款Java 的HTML解析器,可直接解析某个U ...
- ZendFramework2学习笔记 json和ajax
单程: View服务寄存器ViewJsonStrategy之后,有可能直接在控制器action是使用JsonViewModel输出json的数据. 注冊ViewJsonStrategy: //modu ...
- ASP.NET MVC:01理解MVC模式
ASP.NET MVC是ASP.NET Web应用程序框架,以MVC模式为基础. MVC:Model View Controller 模型-视图-控制器Model(模型):负责对数据库的存取View( ...
- 使用cocoapods install友盟时报错Error installing UMengAnalytics
报错: [!] /usr/bin/unzip /Users/soindy/Documents/SmartThermo/ios/SmartThermo/Pods/UMengAnalytics/file. ...