C# | Linq基本功 —— 必学的必熟的10个方法

在这里插入图片描述

C# Linq基本功 —— 必学的必熟的10个方法

1. Linq简介

1.1 什么是Linq

Linq(Language Integrated Query)是C#语言中的一种查询语言,它提供了一种统一的方式来查询和操作各种数据源,如集合、数据库、XML等。Linq的出现使得开发者能够以一种更简洁、更直观的方式来处理数据,提高了代码的可读性和可维护性。

1.2 Linq的优势

Linq具有以下几个优势:

  • 简洁:语法类似于SQL的查询语句,使代码简洁易懂。
  • 强类型:编译时编译器会进行类型检查,降低运行时错误。
  • 可组合:查询操作之间是可以进行组合的(比如在一个查询中嵌套另一个查询),非常灵活。
  • 可扩展:Linq提供了一套标准的查询操作符,同时也支持自定义扩展方法,可以根据需要进行扩展。

2. Linq基本方法

2.1 Where方法

Where方法用于根据指定的条件筛选出符合条件的元素。例如,我们可以使用Where方法从一个整数集合中筛选出所有大于10的元素。

var numbers = new List<int> { 5, 10, 15, 20, 25 };
var result = numbers.Where(n => n > 10);

执行结果:

15, 20, 25

2.2 Select方法

Select方法用于对集合中的每个元素进行转换。例如,我们可以使用Select方法将一个整数集合中的每个元素乘以2。

var numbers = new List<int> { 1, 2, 3, 4, 5 };
var result = numbers.Select(n => n * 2);

执行结果:

2, 4, 6, 8, 10

2.3 OrderBy方法

OrderBy方法用于对集合中的元素进行排序。例如,我们可以使用OrderBy方法对一个字符串集合按照字母顺序进行排序。

var names = new List<string> { "Tom", "Jerry", "Alice", "Bob" };
var result = names.OrderBy(n => n);

执行结果:

Alice, Bob, Jerry, Tom

2.4 GroupBy方法

GroupBy方法用于根据指定的键对集合中的元素进行分组。例如,我们可以使用GroupBy方法将一个学生集合按照班级进行分组。

var students = new List<Student>
{
    new Student { Name = "Tom", Class = "A" },
    new Student { Name = "Jerry", Class = "B" },
    new Student { Name = "Alice", Class = "A" },
    new Student { Name = "Bob", Class = "B" }
};
var result = students.GroupBy(s => s.Class);

执行结果:

A: Tom, Alice
B: Jerry, Bob

2.5 Join方法

Join方法用于将两个集合中的元素进行关联。例如,我们可以使用Join方法将一个学生集合和一个班级集合关联起来。

var students = new List<Student>
{
    new Student { Name = "Tom", ClassId = 1 },
    new Student { Name = "Jerry", ClassId = 2 },
    new Student { Name = "Alice", ClassId = 1 },
    new Student { Name = "Bob", ClassId = 2 }
};
var classes = new List<Class>
{
    new Class { Id = 1, Name = "A" },
    new Class { Id = 2, Name = "B" }
};
var result = students.Join(classes, s => s.ClassId, c => c.Id, (s, c) => new { s.Name, c.Name });

执行结果:

{ Name = "Tom", Name = "A" },
{ Name = "Jerry", Name = "B" },
{ Name = "Alice", Name = "A" },
{ Name = "Bob", Name = "B" }

2.6 Any方法

Any方法用于判断集合中是否存在满足指定条件的元素。例如,我们可以使用Any方法判断一个整数集合中是否存在大于10的元素。

var numbers = new List<int> { 5, 10, 15, 20, 25 };
var result = numbers.Any(n => n > 10);

执行结果:

True

2.7 All方法

All方法用于判断集合中的所有元素是否都满足指定条件。例如,我们可以使用All方法判断一个整数集合中的所有元素是否都大于10。

var numbers = new List<int> { 15, 20, 25 };
var result = numbers.All(n => n > 10);

执行结果:

True

2.8 First方法

First方法用于返回集合中满足指定条件的第一个元素。例如,我们可以使用First方法返回一个整数集合中大于10的第一个元素。

var numbers = new List<int> { 5, 10, 15, 20, 25 };
var result = numbers.First(n => n > 10);

执行结果:

15

2.9 Skip方法

Skip方法用于跳过集合中指定数量的元素。例如,我们可以使用Skip方法跳过一个整数集合中的前两个元素。

var numbers = new List<int> { 1, 2, 3, 4, 5 };
var result = numbers.Skip(2);

执行结果:

3, 4, 5

2.10 Take方法

Take方法用于从集合中取出指定数量的元素。例如,我们可以使用Take方法从一个整数集合中取出前三个元素。

var numbers = new List<int> { 1, 2, 3, 4, 5 };
var result = numbers.Take(3);

执行结果:

1, 2, 3

结语

本文介绍了C# Linq中一些作为基本的扩展方法的使用。掌握这些方法可以帮助开发者更加高效地处理数据。不夸张的说作为一个.NET工程师,不熟练掌握Linq的使用便是不合格。

参考文献:

  • C# Linq基础教程 https://www.runoob.com/w3cnote/csharp-linq-tutorial.html)
  • C# Linq官方文档 https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/concepts/linq/
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
LINQ to SQL语句(1)之Where 2 Where操作 2 1.简单形式: 2 2.关系条件形式: 2 3.First()形式: 3 LINQ to SQL语句(2)之Select/Distinct 3 1.简单用法: 4 2.匿名类型 形式: 4 3.条件形式: 5 4.指定类 型形式: 6 5.筛选形式: 6 6.shaped形式(整形类型): 6 7.嵌套类型形式: 7 8.本地方法调用 形式(LocalMethodCall): 7 9.Distinct形式: 8 LINQ to SQL语句(3)之Count/Sum/Min/Max/Avg 9 1.简单形式: 9 2.带条件形 式: 9 1.简单形式: 10 2.映射形式: 10 3.元素 : 11 1.简单形式: 11 2.映射形式: 11 3.元素: 11 1.简单形式: 12 2.映射形式: 12 3.元素: 12 LINQ to SQL语句(4)之Join 13 Join操作符 13 1.一对多关系(1 to Many): 13 2.多对多关系(Many to Many): 14 3.自联接关系: 15 1.双向联接(Two way join): 15 2.三向联接(There way join): 16 3.左外部联接(Left Outer Join): 17 4.投影的Let赋值(Projected let assignment): 17 5.组合键(Composite Key): 18 6.可为null/不可为null的键关系 (Nullable/Nonnullable Key Relationship): 19 LINQ to SQL语句(5)之Order By 19 Order By操作 19 1.简单形式 19 2.带条件形式 20 3.降序排序 20 4.ThenBy 20 5.ThenByDescending 22 6. 带GroupBy形式 22 LINQ to SQL语句(6)之Group By/Having 23 Group By/Having操作符 23 1.简单形式: 23 2.Select匿名类 : 24 3.最大 值 25 4.最小 值 26 5.平均 值 26 6.求和 26 7.计数 27 8.带条件计数 27 9.Where限制 28 10.多列(Multiple Columns) 28 11.表达式(Expression) 29 LINQ to SQL语句(7)之Exists/In/Any/All/Contains 29 Exists/In/Any/All/Contains操作符 29 Any 29 1.简单形式: 29 2.带条件形式: 30 All 30 Contains 31 1.包含一个对象: 31 2.包含多个值: 32 LINQ to SQL语句(8)之Concat/Union/Intersect/Except 32 Concat/Union/Intersect/Except操作 32 Concat(连接) 32 1.简单形式: 33 2.复 合形式: 33 Union(合并) 33 Intersect(相交) 34 Except(与非) 34 LINQ to SQL语句(9)之Top/Bottom和Paging和SqlMethods 35 Top/Bottom操作 35 Take 35 Skip 35 TakeWhile 36 SkipWhile 36 Paging(分页)操作 36 1.索引 36 2.按唯一键排序 36 SqlMethods操作 37 Like 37 已编译查 询操作(Compiled Query) 38 LINQ to SQL语句(10)之Insert 38 插入(Insert)1.简单形式 38 2.一对多 关系 39 3.多对多关系 39 4.使用动态CUD重写(Override using Dynamic CUD) 40 LINQ to SQL语句(11)之Update 41 更新(Update) 41 1.简单形式 41 2.多项更改 41 LINQ to SQL语句(12)之Delete和使用Attach 42 删除(Delete)1.简单形式 42 2.一对多关系 42 3.推理删除(Inferred Delete) 43 使用Attach更新(Update with Attach) 43 LINQ to SQL语句(13)之开放式并发控制和事务 46 Simultaneous Changes开放式并发控制 46 开放式并发(Optimistic Concurrency) 46 1.Implicit(隐式) 48 2.Explicit(显式) 48 LINQ to SQL语句(14)之Null语义和DateTime 49 Null语义 49 1.Null 49 2.Nullable<T>.HasValue 50 日期函数 50 1.DateTime.Year 51 2.DateTime.Month 51 3.DateTime.Day 51 LINQ to SQL语句(15)之String 51 字符串(String) 51 1.字符 串串联(String Concatenation) 52 2.String.Length 52 3.String.Contains(substring) 52 4.String.IndexOf(substring) 52 5.String.StartsWith (prefix) 53 6.String.EndsWith(suffix) 53 7.String.Substring(start) 53 8.String.Substring (start, length) 53 9.String.ToUpper() 54 10.String.ToLower() 54 11.String.Trim() 54 12.String.Insert(pos, str) 54 13.String.Remove(start) 55 14.String.Remove(start, length) 55 15.String.Replace(find, replace) 55 LINQ to SQL语句(16)之对象标识 56 对象标识 56 对象缓存 56 LINQ to SQL语句(17)之对象加载 57 对象加载延迟加载 57 预先加载:LoadWith 方法 58 LINQ to SQL语句(18)之运算符转换 59 1.AsEnumerable:将类型转换为泛型 IEnumerable 59 2.ToArray:将序列转换为数组 59 3.ToList:将序列转换为 泛型列表 59 4.ToDictionary:将序 列转化为字典 60 LINQ to SQL语句(19)之ADO.NETLINQ to SQL 60 1.连接 61 2.事务 61 LINQ to SQL语句(20)之存储过程 63 1.标量返回 63 2.单一结 果集 64 3.多个可 能形状的单一结果集 65 4.多个结果集 70 5.带输出参数 79 LINQ to SQL语句(21)之用户定义函数 80 1.在Select使用用户定义的标量函数 80 2.在Where从句 使用用户定义的标量函数 81 3.使用用户定义的表值函数 83 4.以联接方式使用用户定义的表值函数 84 LINQ to SQL语句(22)之DataContext 85 创建和删除数据库 85 数据库验证 88 数据库更改 88 动态查询 89 日志 90 LINQ to SQL语句(23)之动态查询 90 1.Select 91 2.Where 92 LINQ to SQL语句(24)之视图 94 LINQ to SQL语句(25)之继承 96 1.一般形式 97 2.OfType形式 98 3.IS形式 98 4.AS形式 99 5.Cast形式 99 6.UseAsDefault形式 100 7.插入新的记录 101
LINQ is one of Microsoft’s most exciting, powerful new development technologies. Essential LINQ is the first LINQ book written by leading members of Microsoft’s LINQ and C# teams. Writing for architects, developers, and development managers, these Microsoft insiders share their intimate understanding of LINQ, revealing new patterns and best practices for getting the most out of it. Calvert and Kulkarni begin by clearly explaining how LINQ resolves the long-time “impedance mismatch” between object-oriented code and relational databases. Next, they show how LINQ integrates querying into C# as a “first-class citizen.” Using realistic code examples, they show how LINQ provides a strongly typed, IntelliSense-aware technology for working with data from any source, including SQL databases, XML files, and generic data structures. Calvert and Kulkarni carefully explain LINQ’s transformative, composable, and declarative capabilities. By fully illuminating these three concepts, the authors allow developers to discover LINQ’s full power. In addition to covering core concepts and hands-on LINQ development in C# with LINQ to Objects, LINQ to XML, LINQ to SQL, and LINQ to Entities, they also present advanced topics and new LINQ implementations developed by the LINQ community. This book • Explains the entire lifecycle of a LINQ project: design, development, debugging, and much more • Teaches LINQ from both a practical and theoretical perspective • Leverages C# language features that simplify LINQ development • Offers developers powerful LINQ query expressions to perform virtually any data-related task • Teaches how to query SQL databases for objects and how to modify those objects • Demonstrates effective use stored procedures and database functions with LINQ • Shows how to add business logic that reflects the specific requirements of your organization • Teaches developers to create, query, and transform XML data with LINQ • Shows how to transform object, relational, and XML data between each other • Offers best patterns and practices for writing robust, easy-to-maintain LINQ code About the Author Charlie Calvert, Community Program Manager for the Microsoft C# team, currently focuses his technical energies on LINQ. He has periodically worked with LINQ Chief Architect Anders Hejlsberg both during the development of Delphi and during the development of LINQ. Calvert’s ten technical books have sold more than 100,000 copies. They include Delphi 4 Unleashed, C++Builder 3 Unleashed, Delphi 2 Unleashed, Teach Yourself Windows 95 Programming in 21 Days, and Teach Yourself Windows Programming. Dinesh Kulkarni is a Senior Program Manager on Microsoft’s .NET Framework team. He was the Program Manager in charge of LINQ to SQL. He was deeply involved in LINQ’s planning and implementation from the incubation stage and was lead author for MSDN’s authoritative LINQ to SQL paper. Before joining Microsoft, he worked in diverse technical roles ranging from architecting and implementing front-end CASE tools for IBM to designing databases and middleware for a Wall Street hedge fund. Product Details Paperback: 600 pages Publisher: Addison-Wesley Professional; 1 edition (March 22, 2009) Language: English ISBN-10: 0321564162 ISBN-13: 978-0321564160

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猿长大人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值