LINQ to Entities 中的查询
查询是一种从数据源检索数据的表达式。 查询通常用专用查询语言表示,如用于关系数据库的 SQL 和用于 XML 的 XQuery。 因此,开发人员对于他们查询的每种类型的数据源或数据格式,都不得不学习一种新的查询语言。 语言集成查询 (LINQ) 为跨各种数据源和格式处理数据提供了一种更简单的、一致的模型。 在 LINQ 查询中,您始终可以使用编程对象。
LINQ 查询操作包含三个操作:获得一个或多个数据源、创建查询并执行查询。
可以通过 LINQ 查询实现 IEnumerable<T> 泛型接口或 IQueryable<T> 泛型接口的数据源。 ObjectQuery<T> 泛型类(可实现泛型 IQueryable<T> 接口)的实例可充当 LINQ to Entities 查询的数据源。 ObjectQuery<T> 泛型类表示一个查询,该查询返回零个或多个类型化对象的集合。 你还可以通过使用 C# 关键字 var
(在 Visual Basic 中为 Dim)让编译器推断实体的类型。
在查询中,您可以确切指定要从数据源检索哪些信息。 查询也可以指定返回信息之前信息的排序、分组和表现方式。 在 LINQ 中,查询存储在变量中。 如果查询返回一系列值,则查询变量本身必须为可查询的类型。 此查询变量不执行任何操作,也不返回任何数据;它只存储查询信息。 创建查询后必须执行该查询以检索任何数据。
查询语法
可以通过两种语法编写 LINQ to Entities 查询:查询表达式语法和基于方法的查询语法。 查询表达式语法是 C# 3.0 和 Visual Basic 9.0 中的新增功能,它由一组用类似于 Transact-SQL 或 XQuery 的声明性语法所编写的子句组成。 不过,.NET Framework 公共语言运行时 (CLR) 无法读取查询表达式语法本身。 因此,在编译时,查询表达式将转换为 CLR 能理解的形式,即方法调用。 这些方法称为“标准查询运算符”。 作为开发人员,您可以选择使用方法语法而不使用查询语法直接调用这些方法。 有关详细信息,请参阅 LINQ 中的查询语法和方法语法。
查询表达式语法
查询表达式是一种声明性查询语法。 通过这一语法,开发人员可以使用类似于 Transact-SQL 的高级语言格式编写查询。 通过使用查询表达式语法,你可以用最少的代码对数据源执行复杂的筛选、排序和分组操作。 有关详细信息,请参阅基本查询操作 (Visual Basic)。 有关演示如何使用查询表达式语法的示例,请参见以下主题:
基于方法的查询语法
另一种编写 LINQ to Entities 查询的方法是使用基于方法的查询。 基于方法的查询语法是一系列针对 LINQ 运算符方法的直接方法调用,同时将 lambda 表达式作为参数传递。 有关详细信息,请参阅 Lambda 表达式。 有关演示如何使用基于方法的语法的示例,请参见以下主题: