Dapper 默认不支持直接映射仅含 private set 的复杂类型属性,需通过 public setter 封装校验逻辑、注册 CustomPropertyTypeMap、使用 AS 别名配合 dynamic/匿名对象读取,或显式传参执行写操作。

Dapper 默认不支持直接映射到仅含 private set 的属性,尤其当属性类型是复杂对象(如自定义类)时。它能自动处理带 private set 的基础类型(如 string、int、DateTime),但对只读属性(get; 无 set)或私有 setter 不可达的场景,需额外干预。
最简单稳妥的做法是把 setter 设为 public,再在内部加保护逻辑,既满足 Dapper 映射,又不破坏业务约束:
public string Name { get; set { _name = string.IsNullOrWhiteSpace(value) ? throw new ArgumentException("Name required") : value.Trim(); } }
当必须保留 strict 封装(如 DDD 领域模型),可用 SqlMapper.SetTypeMap 注册自定义映射器,显式告诉 Dapper 如何设置私有属性:
CustomPropertyTypeMap 子类,重写 GetSetMethod,返回对应私有 setter 的 MethodInfo
SqlMapper.SetTypeMap(typeof(YourEntity), new YourCustomMap()) 全局注册private protected)如果只是读取(SELECT),不依赖强类型实体,可绕过 setter 限制:
AS 对齐属性名:SELECT create_time AS CreateTime FROM book
dynamic 或 IDictionary<string object></string>,再手动构造目标对象写操作无法靠私有 setter 自动填充,推荐显式传参:
connection.Execute("INSERT INTO book (name, author) VALUES (@name, @author)", new { name = book.Name, author = book.Author })
SqlMapper.Bind 或自定义扩展方法可封装复用逻辑基本上就这些。核心原则是:Dapper 优先契约胜于魔法——它不强制你改模型,但需要你明确告诉它“怎么设值”。选哪种方式,取决于你对封装强度、可维护性和团队规范的权衡。
以上就是Dapper如何映射私有属性 Dapper private setter映射方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号