C# LINQ常用语法

1. LINQ 基础概念

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

2. 基本语法结构

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

csharp 复制代码
from 变量 in 数据源
where 条件
orderby 字段
select 结果

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

csharp 复制代码
数据源.方法(参数 => 表达式)

3. 常用的 LINQ 方法

筛选数据 - Where

csharp 复制代码
// 查询表达式
var result = from num in numbers
             where num > 5
             select num;

// 方法语法
var result = numbers.Where(num => num > 5);

排序 - OrderBy / OrderByDescending

csharp 复制代码
// 升序
var result = numbers.OrderBy(num => num);

// 降序
var result = numbers.OrderByDescending(num => num);

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

选择数据 - Select

csharp 复制代码
// 选择特定字段
var names = students.Select(s => s.Name);

// 创建新对象
var studentInfo = students.Select(s => new {
    Name = s.Name,
    Age = s.Age
});

其他常用方法

csharp 复制代码
// 取前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. 实际应用示例

学生数据示例

csharp 复制代码
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 }
};

常见查询操作

csharp 复制代码
// 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 复制代码
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);

字符串数组

csharp 复制代码
string[] names = { "Alice", "Bob", "Charlie", "David" };

// 查找以A开头的名字
var aNames = names.Where(name => name.StartsWith("A"));

// 按长度排序
var sortedByLength = names.OrderBy(name => name.Length);
相关推荐
闻哥3 天前
深入理解 ES 词库与 Lucene 倒排索引底层实现
java·大数据·jvm·elasticsearch·面试·springboot·lucene
龙山云仓3 天前
No140:AI世间故事-对话康德——先验哲学与AI理性:范畴、道德律与自主性
大数据·人工智能·深度学习·机器学习·全文检索·lucene
TracyCoder1235 天前
ElasticSearch核心引擎Apache Lucene(五):相关性算分 (Scoring)
elasticsearch·apache·lucene
TracyCoder1236 天前
ElasticSearch核心引擎Apache Lucene(四):段 (Segment) 的设计与合并
elasticsearch·apache·lucene
TracyCoder1236 天前
ElasticSearch核心引擎Apache Lucene(三):数值与空间数据索引
elasticsearch·apache·lucene
Elastic 中国社区官方博客6 天前
Elasticsearch:Apache Lucene 2025 年终总结
大数据·人工智能·elasticsearch·搜索引擎·apache·lucene
TracyCoder1236 天前
ElasticSearch核心引擎Apache Lucene(二):正排索引的奥秘
elasticsearch·apache·lucene
TracyCoder1236 天前
ElasticSearch核心引擎Apache Lucene(一):倒排索引底层实现
elasticsearch·apache·lucene
程序员agions1 个月前
Unity 游戏开发邪修秘籍:从入门到被策划追杀的艺术
unity·cocoa·lucene
AC赳赳老秦1 个月前
Unity游戏开发实战指南:核心逻辑与场景构建详解
开发语言·spring boot·爬虫·搜索引擎·全文检索·lucene·deepseek