0

0

Dapper的QueryFirst和FirstOrDefault有什么区别 Dapper查询方法选择

月夜之吻

月夜之吻

发布时间:2025-12-29 16:45:08

|

116人浏览过

|

来源于php中文网

原创

QueryFirst要求必须有结果,否则抛InvalidOperationException异常;QueryFirstOrDefault查无结果时返回默认值,更安全。仅当100%确定数据存在时用QueryFirst,如主键查询;多数场景推荐QueryFirstOrDefault。

dapper的queryfirst和firstordefault有什么区别 dapper查询方法选择

QueryFirst 和 QueryFirstOrDefault 的核心区别

两者都用于执行查询并返回单个结果,但对“查不到数据”这一情况的处理完全不同:

  • QueryFirst:要求数据库中必须至少有一行匹配结果。如果没查到,直接抛出 InvalidOperationException 异常。
  • QueryFirstOrDefault:允许查不到数据。此时不报错,而是返回对应类型的默认值——比如引用类型是 nullint0boolfalse

什么时候该用 QueryFirst

仅在你**100%确定某条记录必然存在**时才用它。典型场景包括:

  • 根据主键查询(如 SELECT * FROM Users WHERE Id = @id),且已确认该 ID 在库中一定有值;
  • 聚合查询后必有结果,比如 SELECT COUNT(*) FROM Orders 配合 QueryFirst
  • 业务逻辑强制约束下不可能为空的数据,例如系统配置表的默认项。

为什么多数时候推荐 QueryFirstOrDefault

现实开发中,绝大多数查询都无法提前保证数据一定存在。用 QueryFirst 容易因一条缺失数据导致整个接口崩溃。

  • 查用户信息时 ID 输错、被删除,用 First 会炸,用 FirstOrDefault 返回 null 后可友好提示“用户不存在”;
  • 关联查询中外键可能为空,或条件筛选后无匹配,用 FirstOrDefault 更安全;
  • 配合 if 判断更自然:var user = conn.QueryFirstOrDefault(...); if (user == null) { ... }

别和 Single 系列混淆

QueryFirst / FirstOrDefault 关注的是“取第一个”,不管后面还有没有其他行;而 QuerySingle / SingleOrDefault 要求结果**有且仅有一行**,多于一行也会报错。

  • 邮箱唯一性验证?用 QuerySingleOrDefault,因为期望最多一个;
  • 查最新一条订单?用 QueryFirstOrDefault("SELECT TOP 1 ... ORDER BY Created DESC")
  • 查统计总数?用 QueryFirst("SELECT COUNT(...)") 更合适,因为 COUNT 永远返回一行。

基本上就这些。选哪个不是看名字顺口,而是看你的查询语义和容错需求。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

227

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

432

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

709

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.11.20

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

517

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

48

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

188

2025.08.29

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Java 教程
Java 教程

共578课时 | 39万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号