Dapper如何返回单个实体 Dapper QueryFirstOrDefault用法

来源:站长查询作者:樱由罗头衔:网络博主
导读:本期聚焦于小伙伴创作的《Dapper如何返回单个实体 Dapper QueryFirstOrDefault用法》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Dapper如何返回单个实体 Dapper QueryFirstOrDefault用法》有用,将其分享出去将是对创作者最好的鼓励。

Dapper是.NET平台下轻量级的ORM框架,QueryFirstOrDefault是它提供的用于查询并返回单个实体的核心方法,当查询到匹配结果时返回第一个实体,没有匹配结果时返回对应类型的默认值。

Dapper如何返回单个实体 Dapper QueryFirstOrDefault用法

QueryFirstOrDefault基本用法

QueryFirstOrDefault属于Dapper的SqlMapper扩展方法,最常用的重载形式是接收SQL语句和可选的参数对象,返回指定类型的单个实体。以下是基础的查询示例,假设我们有一个用户表User,对应的实体类定义如下:

public class User
{
    public int Id { get; set; }
    public string UserName { get; set; }
    public string Email { get; set; }
    public int Age { get; set; }
}

查询Id为1的用户实体,代码如下:

using Dapper;
using System.Data.SqlClient;

string connectionString = "Server=127.0.0.1;Database=TestDB;Uid=sa;Pwd=123456;";
using (var connection = new SqlConnection(connectionString))
{
    // 执行查询,返回单个User实体
    User user = connection.QueryFirstOrDefault<User>("SELECT Id, UserName, Email, Age FROM User WHERE Id = @Id", new { Id = 1 });
    if (user != null)
    {
        Console.WriteLine($"用户名称:{user.UserName},年龄:{user.Age}");
    }
    else
    {
        Console.WriteLine("未查询到对应用户");
    }
}

带参数的查询用法

QueryFirstOrDefault支持多种参数传递方式,除了上面的匿名对象参数,还可以使用动态参数DynamicParameters,适合需要动态添加参数的场景:

using Dapper;
using System.Data.SqlClient;

string connectionString = "Server=127.0.0.1;Database=TestDB;Uid=sa;Pwd=123456;";
using (var connection = new SqlConnection(connectionString))
{
    DynamicParameters parameters = new DynamicParameters();
    parameters.Add("UserName", "张三");
    parameters.Add("Age", 25);
    // 查询用户名为张三且年龄为25的用户
    User user = connection.QueryFirstOrDefault<User>("SELECT Id, UserName, Email, Age FROM User WHERE UserName = @UserName AND Age = @Age", parameters);
}

与其他返回单个实体的方法对比

Dapper中还有QueryFirstQuerySingleOrDefault两个返回单个实体的方法,三者的区别如下:

方法名无匹配结果时行为匹配多个结果时行为
QueryFirstOrDefault返回类型默认值(引用类型返回null)返回第一个结果
QueryFirst抛出异常返回第一个结果
QuerySingleOrDefault返回类型默认值(引用类型返回null)抛出异常

使用注意事项

  • 如果查询的字段名和实体属性名不一致,需要使用AS关键字给字段取别名,或者在实体属性上使用[Column]特性映射,否则对应属性会被赋值为默认值。
  • 当返回值是值类型时,QueryFirstOrDefault返回的是该值类型的默认值,比如查询int类型字段没有结果时返回0,需要和业务场景区分判断。
  • 方法内部会自动打开和关闭数据库连接,不需要手动调用Open()方法,但是如果连接已经打开,方法不会重复打开。

总结

QueryFirstOrDefault是Dapper中返回单个实体最常用的方法之一,适合不需要严格限制结果数量的查询场景,使用起来简单灵活。开发者可以根据实际的查询需求选择合适的方法,同时做好返回值的空判断,避免出现运行时异常。在实际项目中,结合参数化查询可以有效防止SQL注入,提升代码的安全性。

DapperQueryFirstOrDefault单个实体ORM数据库查询修改时间:2026-07-02 22:27:31

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。