7-Linq查询语言
本篇博客对应视频讲解
回顾
上一期我们讲解了字符编码相关的内容,大家应该去理解字符和字节之间的关系。并学习使用Encoding类进行编码之间的转换。
今天给大家讲的内容十分的重要,也是C#等语言比其他语言更具优势的地方。它将极大的提高我们处理数据的效率,提升我们的开发体验。
何为LINQ
LINQ(Language Integrated Query)语言集成查询,允许以查询数据库相同的方式操作内存数据。
简单的说,我们有很多数据来源,数据库、文件(xml、json),内存中的数据等等。我们需要针对不同的数据类型使用不同的方法进行操作。
例如,我们处理字符串,就需要使用String类,处理列表需要使用List类中提供的方法,查询数据库更是需要特定的sql查询语言支持,非常的繁琐。而Linq就是更高层次的抽象,可应用于所有数据源的具有多种用途的语法查询特性。
这意味着,我们只需要学习一种查询方法,就可以处理各种数据了。
Linq相当的便捷和实用,正因如此,当Linq出现之后,其他语言也有相关的实现。
使用LINQ
首先给大家官方文档的地址,里面非常详细的介绍和说明了怎么使用Linq进行数据的查询和处理。
完整文档参考。
建议大家有时间就对这个文档的内容进行总体浏览,了解都包含哪些内容。之后遇到需求的时候可以有针对性的去查找 。
今天我会给出一些示例,让大家领略一下Linq的威力。
示例代码:
- 简单数组Linq操作
var numbers = new int[] { 1, 31, 22, 4, 229, 84, 8, 23 };
Console.WriteLine("原数组:");
WriteArray(numbers);
// 取最大值
int max = numbers.Max();
Console.WriteLine("最大值为:" + max);
// 取第三大的值
int thirdMax = numbers.OrderByDescending(m => m)
.Skip(2)
.First();
Console.WriteLine("第三大的数是" + thirdMax);
// 取总和
int sum = numbers.Sum();
Console.WriteLine("总和为:" + sum);
// 条件筛选,取所有奇数,并按从小到大排列
var result = numbers.Where(n => n % 2 == 1)
.OrderBy(m => m)
.ToArray();
Console.WriteLine("处理后的结果为:");
WriteArray(result);
数组输出方法
static void WriteArray(IEnumerable obj)
{
foreach (var item in obj)
{
Console.Write(item.ToString() + " ");
}
Console.WriteLine();
}
- 学生考试成绩查询
我们先创建学生和成绩类:
Student类:Name,Class,Score
Score类:English,Chinese,Math
/// <summary>
/// 成绩类
/// </summary>
public class Score
{
/// <summary>
/// 数学
/// </summary>
public int Math { get; set; }
/// <summary>
/// 英语
/// </summary>
public int English { get; set; }
/// <summary>
/// 语文
/// </summary>
public int Chinese { get; set; } } /// <summary>
/// 学生类
/// </summary>
class Student
{
/// <summary>
/// 姓名
/// </summary>
public string Name { get; set; }
/// <summary>
/// 班级
/// </summary>
public string Class { get; set; } /// <summary>
/// 成绩
/// </summary>
public Score Score { get; set; }
}
使用Linq代码示例:
先模拟我们需要数据
/// <summary>
/// 初始化数据
/// </summary>
/// <returns></returns>
static List<Student> InitData()
{
string[] names = { "张三", "王五", "李四", "赵二", "丁一", "李明", "韩梅", "梦琪", "忆柳", "之桃", "慕青", "问兰", "尔岚", "元香", "初夏" };
var random = new Random(); var students = new List<Student>();
// 创建学生对象
foreach (var name in names)
{
var student = new Student
{
Name = name,
Class = random.Next(1, 4) + "班"
};
students.Add(student);
}
// 模拟学生考试成绩
foreach (var student in students)
{
var score = new Score
{
Chinese = random.Next(60, 101),
English = random.Next(60, 101),
Math = random.Next(60, 101)
};
student.Score = score; Console.WriteLine($"{student.Class}[{student.Name}]的成绩为:" +
$"数学:{score.Math};语文:{score.Chinese};英语:{score.English}" +
$"总分为:{score.Math + score.Chinese + score.English}");
} return students;
}
查询数据
// 初始化数据
var students = InitData();
// 找出总分最高的学生
var student = students.Select(s =>
{
return new
{
Sum = s.Score.Chinese + s.Score.English + s.Score.Math,
s.Name
};
}).OrderByDescending(s => s.Sum)
.First();
Console.WriteLine("总分最高的学生是:" + student.Name + ";总分为:" + student.Sum);
// 找出平均分最高的班级
var topClass = students.GroupBy(s => s.Class)
.Select(s =>
{
return new
{
Average = s.Sum(m => m.Score.Chinese + m.Score.English + m.Score.Math) / s.Count(),
Class = s.Key
};
})
.OrderByDescending(m => m.Average);
Console.WriteLine("最高班级:" + topClass.First().Class + ";平均分:" + topClass.First().Average);
// 筛选出有分数小于80分的学生,按班分组
var hardStudents = students.Where(m => needImprove(m.Score))
.GroupBy(m => m.Class)
.ToList();
// 输出每班内小于80分的同学
foreach (var group in hardStudents)
{
Console.WriteLine(group.Key + "有低于80分学生" + group.Count() + "名:");
foreach (var item in group)
{
Console.Write(item.Name + " ");
}
Console.WriteLine();
}
// 内部方法,判断是否有小于80分的学科
bool needImprove(Score score)
{
if (score.English < 80 || score.Chinese < 80 || score.Math < 80)
return true;
return false;
}
7-Linq查询语言的更多相关文章
- 29.LINQ初探
本页内容: 1.LINQ查询语言的组成部分: 2.使用LINQ方法语法: 3.排序查询结果 orderby 字句: 4.聚合运算符: 5.查询复杂对象: 6.投影:在查询中创建新对象: 7.Disti ...
- 分布式消息总线,基于.NET Socket Tcp的发布-订阅框架之离线支持,附代码下载
一.分布式消息总线以及基于Socket的实现 在前面的分享一个分布式消息总线,基于.NET Socket Tcp的发布-订阅框架,附代码下载一文之中给大家分享和介绍了一个极其简单也非常容易上的基于.N ...
- AgileEAS.NET SOA 中间件平台5.2版本下载、配置学习(一):下载平台并基于直连环境运行
一.前言 AgileEAS.NET SOA 中间件平台是一款基于基于敏捷并行开发思想和Microsoft .Net构件(组件)开发技术而构建的一个快速开发应用平台.用于帮助中小型软件企业建立一条适合市 ...
- 2016 .net 招聘
职位月薪:面议 工作地点:成都 发布日期:2016-02-23 工作性质:全职 工作经验:1-3年 最低学历:大专 招聘人数:5人 职位类别:软件工程师 岗位职责: 1. 负责项目或产品的开发.单 ...
- 编程语言的发展趋势by Anders Hejlsberg
这是Anders Hejlsberg在比利时TechDays 2010所做的开场演讲. 编程语言的发展非常缓慢,期间也当然出现了一些东西,例如面向对象等等,你可能会想,那么我么这么多年的努力都到哪里去 ...
- 4-C#格式处理
本篇博客对应视频讲解 前言 前几篇文章及对应视频是带大家快速体验了一下C#,了解编程语言最基础的内容及面向对象的概念. 接下来我会进一步演示和说明C#还能做些什么. 实际上,C#就一门语言来讲,除去面 ...
- [C#] 走进 LINQ 的世界
走进 LINQ 的世界 序 在此之前曾发表过三篇关于 LINQ 的随笔: 进阶:<LINQ 标准查询操作概述>(强烈推荐) 技巧:<Linq To Objects - 如何操作字符串 ...
- LinQ to SQL用法详解
LinQ是指集成化查询语言,通过映射将数据库内的表名变为C#的类名,将列名作为属性名,将表的关系作为类的成员对象.O--M--R O-Object对象(李昌辉)R-Relation关系M-Mappin ...
- linQ学习笔记之一
linq解决的问题 1.编程语言中的数据类型与数据库中的数据类型形成的两套体系 2.SQL编码体验落后 3.SQL和XML都有各自的查询语言,而对象没有自己的查询语言 linq简单的集合查询和fore ...
- LINQ 的使用
[转]链接:cnblogs.com/liqingwen/p/5832322.html LINQ 简介 语言集成查询 (LINQ) 是 Visual Studio 2008 和 .NET Framewo ...
随机推荐
- Nginx Linux yum安装
-- 安装>yum install nginx -y -- 查看>whereis nginx >目录>/usr/sbin/nginx 执行命令>/etc/nginx 配置 ...
- SQLITE3 使用总结(转)
前序: Sqlite3 的确很好用.小巧.速度快.但是因为非微软的产品,帮助文档总觉得不够.这些天再次研究它,又有一些收获,这里把我对 sqlite3 的研究列出来,以备忘记. 这里要注明,我是一个跨 ...
- The web application [/zzti] registered the JDBC driver [com.microsoft.sqlserver.jdbc.SQLServerDriver
先说下题目:因为是在我进行处理项目升级时同时遇到了上面的问题,一般都会遇到,所以就一并说了 不罗嗦了,正题: 在本地服务器中提供tomcat6,然后在myeclipse中配置severs tomcat ...
- 解决CentOS内网机通过Windows下架设代理来访问网络
新分配的CentOS运行在内网环境下,无法连接Internet,为了能够使用yum部署OpenVas工具,需要在内网下一台Windows主机架设代理,作代理服务器来令虚拟机上网. 代理服务器选择了CC ...
- Win7删除远程连接历史记录
打开注册表,找到 HKEY_CURRENT_USER\Software\Microsoft\Terminal Server Client\Default 删除右侧的 MRUn(n是索引号) 项 即可.
- mysql常用语句及关键字
一.常用sql语句 1.创建数据库userCREATE DATABASE user; 2.删除数据库userDROP DATABASE user; 3.使用数据库userUSE user;显示数据库 ...
- 117. Populating Next Right Pointers in Each Node II (Tree; WFS)
Follow up for problem "Populating Next Right Pointers in Each Node". What if the given tre ...
- ssh 连接很慢的解决办法
http://blog.csdn.net/ablo_zhou/article/details/5074887 ============= 现象: 在局域网内,能ping通目标机器,并且时延是微秒级. ...
- php 共享内存学习(shmop函数)
问题:希望可以在进程间共享变量,为共享数据提供快速访问 解决方案:除了可以使用APC模块,还可以用shmop或System V共享内存 //创建键 //将一个可访问的文件路径名转换为一个可供 shmo ...
- genymotion的安装
1.安装virtualBox google的模拟器是运行在qemu上面的. genymotion这个模拟器运行在virtualBox上面.