IQueryable
IQueryable 接口是用于构建查询的,它的方法不会直接操作数据库。相反,它会构建查询表达式,并在执行时将这些表达式转换为适当的 SQL 查询,然后发送到数据库执行。
| where | 根据指定的条件过滤查询结果,生成 SQL 中的 WHERE 子句。 |
| OrderBy / OrderByDescending | 对查询结果进行排序,生成 SQL 中的 ORDER BY 子句。 |
| Select | 选择查询结果中的特定字段或属性,生成 SQL 中的 SELECT 子句。 |
| Skip / Take | 分页查询,生成 SQL 中的 OFFSET 和 FETCH 子句。 |
| GroupBy | 对查询结果进行分组,生成 SQL 中的 GROUP BY 子句。 |
| Any / All | 判断查询结果中是否存在满足特定条件的元素,生成 SQL 中的 EXISTS 子句。 |
| Join | 将两个查询结果进行连接,生成 SQL 中的 JOIN 子句。 |
| WhereIf | 根据指定的条件,在满足条件时才应用 WHERE 子句,生成 SQL 中的 WHERE 子句。 |
| PageBy | 用于分页查询,根据指定的 SkipCount 和 MaxResultCount 参数生成 SQL 中的 OFFSET 和 FETCH 子句。 |
| Contains | 用于检查查询结果是否包含特定元素。 |
| AsNoTracking | 对数据库执行查询时,EF Core 默认会跟踪返回的实体。这意味着 EF Core 会维护这些实体的一个副本,并且对这些实体进行的任何更改都会被追踪和记录下来。这对于需要更新、删除等操作非常有用。然而,对于只读操作,这种跟踪机制会带来额外的开销,并且在很多情况下是不必要的。 |
| DeleteAsync | 用于异步删除单个实体对象。它接受一个参数,即要删除的实体对象的标识符或实体对象本身,并将其从数据库中删除。这个方法通常在异步环境中使用,以确保数据库操作不会阻塞应用程序的其他操作。在删除操作完成后,通常会返回一个表示操作完成的任务。 有三个重载方法,可以是Ids,可以是实体类,可以是删除条件的表达式 |
构建数据库语句方法和执行数据库语句方法
IQueryable 有一些方法是构建sql语句但是不执行,有一些方法是执行sql语句
-
将表达式转换为适当的 SQL 查询:
- Where: 根据指定的条件过滤查询结果,生成 SQL 中的 WHERE 子句。
- OrderBy / OrderByDescending: 对查询结果进行排序,生成 SQL 中的 ORDER BY 子句。
- Select: 选择查询结果中的特定字段或属性,生成 SQL 中的 SELECT 子句。
- Skip / Take: 分页查询,生成 SQL 中的 OFFSET 和 FETCH 子句。
- GroupBy: 对查询结果进行分组,生成 SQL 中的 GROUP BY 子句。
- Any / All: 判断查询结果中是否存在满足特定条件的元素,生成 SQL 中的 EXISTS 子句。
- Join: 将两个查询结果进行连接,生成 SQL 中的 JOIN 子句。
- WhereIf: 根据指定的条件,在满足条件时才应用 WHERE 子句,生成 SQL 中的 WHERE 子句。
- PageBy: 用于分页查询,根据指定的 SkipCount 和 MaxResultCount 参数生成 SQL 中的 OFFSET 和 FETCH 子句。
-
Contains:用于检查查询结果是否包含特定元素。 -
AsNoTracking:对数据库执行查询时,EF Core 默认会跟踪返回的实体。这意味着 EF Core 会维护这些实体的一个副本,并且对这些实体进行的任何更改都会被追踪和记录下来。这对于需要更新、删除等操作非常有用。然而,对于只读操作,这种跟踪机制会带来额外的开销,并且在很多情况下是不必要的。
这些方法并不会立即执行查询,而是构建一个查询表达式。
-
触发实际的数据库查询操作:
当调用以下方法时,会触发实际的数据库查询操作:
- ToList(): 执行查询并将结果加载到内存中的列表中。
- FirstOrDefault() / First(): 返回查询结果的第一个元素,或者默认值。
- Single() / SingleOrDefault(): 返回查询结果中的唯一元素,或者默认值。
- Count(): 返回查询结果的数量。
- Any(): 检查查询结果中是否存在满足条件的元素。
- All(): 检查查询结果中的所有元素是否都满足条件。
这些方法会触发实际的数据库查询,并将结果返回给调用方。