IQueryable 常用方法

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语句

  1. 将表达式转换为适当的 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 会维护这些实体的一个副本,并且对这些实体进行的任何更改都会被追踪和记录下来。这对于需要更新、删除等操作非常有用。然而,对于只读操作,这种跟踪机制会带来额外的开销,并且在很多情况下是不必要的。

这些方法并不会立即执行查询,而是构建一个查询表达式。

  1. 触发实际的数据库查询操作

    当调用以下方法时,会触发实际的数据库查询操作:

    • ToList(): 执行查询并将结果加载到内存中的列表中。
    • FirstOrDefault() / First(): 返回查询结果的第一个元素,或者默认值。
    • Single() / SingleOrDefault(): 返回查询结果中的唯一元素,或者默认值。
    • Count(): 返回查询结果的数量。
    • Any(): 检查查询结果中是否存在满足条件的元素。
    • All(): 检查查询结果中的所有元素是否都满足条件。

这些方法会触发实际的数据库查询,并将结果返回给调用方。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值