C# LINQ常用语法及实际应用示例

 更新时间:2025年10月21日 14:46:04   作者:酥酥禾  
LINQ (Language Integrated Query) 是C#中用于数据查询的语法,可以查询各种数据源(数组、集合、数据库等),本文给大家介绍C# LINQ常用语法,感兴趣的朋友跟随小编一起看看吧

1. LINQ 基础概念

LINQ (Language Integrated Query) 是 C# 中用于数据查询的语法,可以查询各种数据源(数组、集合、数据库等)。

2. 基本语法结构

查询表达式语法(类似 SQL)

from 变量 in 数据源
where 条件
orderby 字段
select 结果

方法语法(使用 Lambda 表达式)

数据源.方法(参数 => 表达式)

3. 常用的 LINQ 方法

筛选数据 - Where

// 查询表达式
var result = from num in numbers
             where num > 5
             select num;
// 方法语法
var result = numbers.Where(num => num > 5);

排序 - OrderBy / OrderByDescending

// 升序
var result = numbers.OrderBy(num => num);
// 降序
var result = numbers.OrderByDescending(num => num);
// 多字段排序
var result = students.OrderBy(s => s.Age)
                    .ThenBy(s => s.Name);

选择数据 - Select

// 选择特定字段
var names = students.Select(s => s.Name);
// 创建新对象
var studentInfo = students.Select(s => new {
    Name = s.Name,
    Age = s.Age
});

其他常用方法

// 取前N个
var top3 = numbers.Take(3);
// 跳过前N个
var afterFirst3 = numbers.Skip(3);
// 判断是否存在
bool hasEven = numbers.Any(n => n % 2 == 0);
// 判断是否所有元素都满足条件
bool allPositive = numbers.All(n => n > 0);
// 获取第一个元素
var first = numbers.First();
// 获取最后一个元素
var last = numbers.Last();
// 计数
int count = numbers.Count();
// 求和
int sum = numbers.Sum();
// 最大值
int max = numbers.Max();
// 最小值
int min = numbers.Min();
// 平均值
double average = numbers.Average();

4. 实际应用示例

学生数据示例

class Student
{
    public string Name { get; set; }
    public int Age { get; set; }
    public int Score { get; set; }
}
List<Student> students = new List<Student>
{
    new Student { Name = "Alice", Age = 20, Score = 85 },
    new Student { Name = "Bob", Age = 22, Score = 90 },
    new Student { Name = "Charlie", Age = 19, Score = 78 }
};

常见查询操作

// 1. 筛选年龄大于20的学生
var olderStudents = students.Where(s => s.Age > 20);
// 2. 按分数降序排序
var sortedByScore = students.OrderByDescending(s => s.Score);
// 3. 选择学生姓名和分数
var nameScores = students.Select(s => new { 
    s.Name, 
    s.Score 
});
// 4. 获取分数最高的学生
var topStudent = students.OrderByDescending(s => s.Score).First();
// 5. 计算平均分
var averageScore = students.Average(s => s.Score);
// 6. 分组查询
var groupByAge = students.GroupBy(s => s.Age);

5. 在数组和集合中的应用

数组操作

csharp
int[] numbers = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
// 获取偶数
var evenNumbers = numbers.Where(n => n % 2 == 0);
// 平方每个数
var squares = numbers.Select(n => n * n);
// 获取大于5的数并排序
var result = numbers.Where(n => n > 5)
                   .OrderBy(n => n);

字符串数组

string[] names = { "Alice", "Bob", "Charlie", "David" };
// 查找以A开头的名字
var aNames = names.Where(name => name.StartsWith("A"));
// 按长度排序
var sortedByLength = names.OrderBy(name => name.Length);

到此这篇关于C# LINQ常用语法的文章就介绍到这了,更多相关C# LINQ语法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#下listview如何插入图片

    C#下listview如何插入图片

    这篇文章主要为大家详细介绍了C#下listview如何插入图片,如何在listview中插入图片的每一个步骤为大家分享,感兴趣的朋友可以参考一下
    2016-05-05
  • C#图像处理之图像目标质心检测的方法

    C#图像处理之图像目标质心检测的方法

    这篇文章主要介绍了C#图像处理之图像目标质心检测的方法,可实现C#计算图像质心的相关技巧,需要的朋友可以参考下
    2015-04-04
  • C# 将 Stream 保存到文件的方法

    C# 将 Stream 保存到文件的方法

    这篇文章主要介绍了C#将 Stream保存到文件的方法,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-08-08
  • C#正则函数用法实例【匹配、替换、提取】

    C#正则函数用法实例【匹配、替换、提取】

    这篇文章主要介绍了C#正则函数用法,结合实例形式分析了C#基于正则的匹配、替换、提取相关操作技巧,需要的朋友可以参考下
    2017-01-01
  • C#实现将Doc文档转换成rtf格式的方法示例

    C#实现将Doc文档转换成rtf格式的方法示例

    这篇文章主要介绍了C#实现将Doc文档转换成rtf格式的方法,结合实例形式分析了C#针对word文件的读取及文档格式转换相关操作技巧,需要的朋友可以参考下
    2017-07-07
  • C#中TextBox实现输入提示功能的方法

    C#中TextBox实现输入提示功能的方法

    这篇文章主要介绍了C#中TextBox实现输入提示功能的方法,涉及C#中TextBox的相关操作技巧,需要的朋友可以参考下
    2015-06-06
  • C#生成随机验证码代码分享

    C#生成随机验证码代码分享

    这篇文章主要分享了C#生成随机验证码代码,另外附上使用示例,非常的简单实用,有需要的朋友可以参考下
    2014-10-10
  • C# WebApi+Webrtc局域网音视频通话实例

    C# WebApi+Webrtc局域网音视频通话实例

    这篇文章主要为大家详细介绍了C# WebApi+Webrtc局域网音视频通话实例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C#中的并发集合Concurrent类

    C#中的并发集合Concurrent类

    这篇文章介绍了C#中的并发集合Concurrent类,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • 使用C#实现设置 Excel单元格格式的示例详解

    使用C#实现设置 Excel单元格格式的示例详解

    这篇文章主要为大家详细介绍了如何通过使用C#在同一个工作表中设置 字体、背景颜色、行高列宽、边框和单元格合并,文中的示例代码讲解详细,需要的小伙伴可以了解下
    2025-09-09

最新评论