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(): 检查查询结果中的所有元素是否都满足条件。
 
这些方法会触发实际的数据库查询,并将结果返回给调用方。