Dapper通过Multi-Mapping、QueryMultiple和字典缓存三种方式处理多表关联:一对一用Query配合splitOn和委托组装;一对多用字典去重聚合;多独立结果集用QueryMultiple一次性查询。

Dapper 本身不自动处理多表关联的嵌套对象,但通过 Multi-Mapping(多映射) 和 QueryMultiple 两种核心方式,可以干净、高效地把一个或多个结果集映射到多个 .NET 对象。关键不是“能不能”,而是选对方法——取决于你查的是一对多、一对一,还是完全无关的多结果集。
这是最常用的方式,适合主从结构清晰、且从表最多一条记录的场景(比如 Post + User、Order + Customer)。Dapper 把一行结果按指定列“切开”,前半段给第一个类型,后半段给第二个类型,再由你写委托组装。
(post, user) => { post.Owner = user; return post; },Dapper 不会自动设属性post.Owner?.Name
单行 SQL 返回多条子记录时(比如 1 篇文章带 5 条评论),Query 会生成 5 个重复的 Post 实例。正确做法是手动去重+聚合:
Dictionary<int post> lookup = new()</int> 缓存已创建的 PostIEnumerable<post></post>,每个 Post 的 Comments 已填充好当你要查的数据彼此无关(比如同时加载用户列表 + 订单统计 + 配置项),或一对多关系太复杂不适合单 SQL JOIN 时,QueryMultiple 更稳:
"SELECT * FROM Users; SELECT COUNT(*) FROM Orders; SELECT * FROM Configs"
var multi = connection.QueryMultiple(sql),然后依次 multi.Read<user>()</user>、multi.ReadSingle<int>()</int>、multi.Read<config>()</config>
基本上就这些。没有银弹,一对一用 Multi-Mapping,一对多靠字典缓存,多结果集用 QueryMultiple——选对路子,映射就不卡壳。
以上就是Dapper如何映射多个对象 Dapper多表查询映射指南的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号