新闻中心

Dapper如何映射私有属性 Dapper private setter映射方法

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

dapper如何映射私有属性 dapper private setter映射方法

Dapper 默认不支持直接映射到仅含 private set 的属性,尤其当属性类型是复杂对象(如自定义类)时。它能自动处理带 private set 的基础类型(如 stringintDateTime),但对只读属性(get;set)或私有 setter 不可达的场景,需额外干预。

用 public setter + 封装逻辑替代

最简单稳妥的做法是把 setter 设为 public,再在内部加保护逻辑,既满足 Dapper 映射,又不破坏业务约束:

  • 例如:public string Name { get; set { _name = string.IsNullOrWhiteSpace(value) ? throw new ArgumentException("Name required") : value.Trim(); } }
  • 避免完全暴露字段,而是把校验/转换逻辑放进 setter 中
  • 适用于多数业务实体,开发和调试都直观

注册 CustomPropertyTypeMap 实现私有 setter 映射

当必须保留 strict 封装(如 DDD 领域模型),可用 SqlMapper.SetTypeMap 注册自定义映射器,显式告诉 Dapper 如何设置私有属性:

  • 创建 CustomPropertyTypeMap 子类,重写 GetSetMethod,返回对应私有 setter 的 MethodInfo
  • 调用 SqlMapper.SetTypeMap(typeof(YourEntity), new YourCustomMap()) 全局注册
  • 注意:Dapper 6.0+ 对私有 setter 支持增强,但仍不自动识别复杂类型赋值,需确保 setter 可被反射访问(如非 private protected

查询阶段用 AS 别名 + 动态/匿名对象过渡

如果只是读取(SELECT),不依赖强类型实体,可绕过 setter 限制:

DeepBrain DeepBrain

AI视频生成工具,ChatGPT +生成式视频AI =你可以制作伟大的视频!

DeepBrain 146 查看详情 DeepBrain
  • SQL 中用 AS 对齐属性名:SELECT create_time AS CreateTime FROM book
  • 先查为 dynamicIDictionary<string object></string>,再手动构造目标对象
  • 适合报表、DTO 映射等一次性场景,灵活但稍冗余

插入/更新时用匿名对象或 ExpandoObject

写操作无法靠私有 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映射方法的详细内容,更多请关注其它相关文章!


# 中文网  # 香洲区会计网站建设  # seo精准引擎搜索系统  # 滨州抖音首页关键词排名推广  # 淮南网站首页优化去哪找  # 网站怎么优化百度收录  # 潮州抖音营销怎么做推广  # 吉安建设网站公司  # 孝感网站优化方案  # 邯郸seo推广如何进行  # seo叫什么区别  # app  # 自动识别  # 相关文章  # 适用于  # 设为  # 则是  # 你可以  # 不支持  # 自定义  # 子类  # red 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 如何解决电商平台定制报价请求的“黑洞”问题,SprykerQuoteRequest模块助你提升客户体验与销售效率  Python vgamepad库按键模拟:正确使用XUSB_BUTTON常量  蛙漫漫画官网在线入口 蛙漫全本漫画免费阅读平台  天眼查企业查询官网入口 天眼查官方网页版查询  Win10如何清理注册表垃圾 Win10手动清理无效注册表【技巧】  优酷会员付费后没到账怎么办_优酷会员充值异常及解决方法  学习通在线学习平台 学习通网页版直接进入课程中心  蛙漫限时开放最深处链接_蛙漫全站漫画会员同款秒开地址  内存检查:在VS Code中调试C++时的内存视图  Eclipse怎么运行工程_Eclipse工程运行配置说明  Surface怎么安装系统 微软Surface Pro U盘重装win11教程  PySpark中从现有列右侧提取可变长度字符创建新列的教程  豆包手机助手发布技术预览版:直接嵌入手机系统!努比亚样机发售  163邮箱注册官网 免费申请163个人邮箱  AngularJS $http POST请求数据传递与Go后端接收实践  Win10快速启动功能利弊分析 Win10开启或关闭快速启动教程【技巧】  PHP URL参数传递与500错误调试指南  Golang如何使用new_Go new分配内存机制讲解  C++的std::forward_list怎么用_C++ STL中单向链表容器的特点与应用  CSS Flexbox如何实现多行排列_flex-wrap wrap自动换行显示  天眼查怎么看公司融资情况 天眼查企业融资历史查询步骤【攻略】  邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧  深入理解Google Cloud Datastore查询:祖先路径与数据一致性  c++ 获取系统当前时间 c++时间戳获取方法  Centos/Linux 系统下安装 composer 的完整步骤  电脑安装程序提示“错误1722”怎么办_Windows Installer服务问题解决【教程】  Composer如何解决json扩展缺失的错误  css元素hover动画延迟生效怎么办_使用animation-delay调整触发时间  电脑IP地址怎么查 查看本机IP地址的几种方法  Python大型XML文件高效流式解析教程  fishbowl官网免费版 fishbowl养鱼网站入口  2025年云电脑操作系统体验 | 无需本地硬件,随时随地使用高性能PC  Golang如何实现微服务鉴权与权限控制_Golang微服务鉴权与权限管理实践  拼多多购物车商品数量无法修改如何处理 拼多多购物车操作优化方法  Lar*el用户头像管理:实现图片缩放、存储与旧文件安全删除的最佳实践  必由学官方网站入口 必由学学生教师共用登录通道  提升屏幕阅读器对“m”时间单位的播报准确性:HTML与CSS组合解决方案  处理动态列数据:J*a ArrayList的正确初始化与字符累加教程  qq浏览器如何查看和导出已保存的密码 qq浏览器密码管理器数据备份教程  Node.js CSV 数据处理:基于字段值条件过滤整条记录的策略  C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器  WordPress插件开发:正确注册卸载钩子与避免常见陷阱  小猿搜题在线学习页面在哪_小猿搜题在线学习中心入口  PowerPoint如何制作滚动字幕结尾彩蛋_PowerPoint路径动画实现平滑滚动字幕效果  零跑汽车11月交付量达70327台 实现连续9个月正增长  俄罗斯方块最新版入口 俄罗斯方块在线玩官网入口  在React函数组件中利用原生HTML5进行邮箱地址验证  如何设置Windows Defender的定时扫描_计划任务实现自动杀毒【安全】  C++指针和引用有什么区别_C++内存管理核心概念深度解析  J*aScript中针对特定容器内图片动画的实现教程 

搜索