Dapper.FluentMap是什么 Dapper.FluentMap流畅映射配置教程

Dapper.FluentMap 是一个为 Dapper 设计的轻量级编译期映射配置库,通过 Fluent API 在启动时注册列名映射规则,解决数据库下划线命名、字段前缀/后缀、审计字段忽略及统一约定等场景,需在首次查询前完成 Initialize 初始化。

dapper.fluentmap是什么 dapper.fluentmap流畅映射配置教程

Dapper.FluentMap 是什么

Dapper.FluentMap 是一个为 Dapper 设计的轻量级映射配置扩展库,用于解决“数据库列名与 C# 属性名不一致”时的手动映射问题。它不改变 Dapper 的核心行为,也不引入运行时反射开销,而是通过编译期友好的 Fluent API,在应用启动时一次性注册映射规则,让 Dapper 知道“哪个属性对应哪一列”或“哪些属性该忽略”。

它特别适合这些场景: – 数据库用下划线命名(user_name)而实体用 PascalCase(UserName) – 表字段含前缀(如 tbl_user_id)或后缀(如 created_dt) – 某些字段纯属审计列(updated_by, is_deleted),不想映射进实体 – 需要统一约定(比如所有 Id 属性都映射到 autID)而不逐个写 SQL 别名

基础映射配置步骤

User 实体为例,假设数据库表字段是 usr_idusr_nameusr_email,而 C# 类是:

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

你需要:

创建映射类,继承 EntityMap在构造函数中用 Map() 显式指定列名,或用 Ignore() 跳过字段在程序启动时(如 Program.csStartup.ConfigureServices)调用 FluentMapper.Initialize() 注册

示例代码:

public class UserMap : EntityMap
{
  public UserMap()
  {
    Map(x => x.Id).ToColumn(“usr_id”);
    Map(x => x.Name).ToColumn(“usr_name”);
    Map(x => x.Email).ToColumn(“usr_email”);
  }
}

FluentMapper.Initialize(config =>
{
  config.AddMap(new UserMap());
});

忽略字段和约定式映射

如果实体里有不对应数据库列的属性(比如 FullName 计算属性),必须显式忽略,否则 Dapper 可能报错或静默跳过:

Map(x => x.FullName).Ignore();

若多个实体都有类似规则(例如所有 Id 属性都映射到带前缀的列),可用 约定(Convention) 统一处理:

新建类继承 ConventionProperties().Where(...) 定位目标属性调用 Configure(c => c.HasColumnName(...)) 设置列名在 Initialize 中用 AddConvention() 加载

这样比每个实体写一遍 Map 更干净,也更易维护。

注意事项和常见坑

配置生效的前提是:必须在任何 Dapper 查询执行前完成初始化。常见错误包括:

映射类没在 Initialize 中注册——查询时仍按默认规则(属性名=列名)匹配忽略语句写错位置(比如放在 Map 外部)——Ignore() 必须链在 Map(x => ...) 后面使用了 Dapper.Contrib 的 CRUD 方法(如 GetAsync)但没配 KeyTable 特性——FluentMap 不影响 Contrib 的特性解析,二者需配合使用多线程环境下提前触发了 Dapper 查询——确保 FluentMapper.Initialize 在主线程或 DI 容器构建完成后再执行

基本上就这些。不复杂但容易忽略初始化时机和链式调用结构。

以上就是Dapper.FluentMap是什么 Dapper.FluentMap流畅映射配置教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1443020.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 19:38:15
下一篇 2025年12月10日 06:14:29

相关推荐

  • Blazor 依赖注入(DI)配置和使用方法

    Blazor依赖注入是框架级基础设施,服务需在Program.cs中按生命周期注册(Singleton/Scoped/Transient),组件用@inject或构造函数注入,自定义服务须接口+实现+注册闭环,Scoped在WebAssembly中按标签页隔离。 Blazor 依赖注入(DI)不是可…

    2025年12月17日
    000
  • Ant Design of Blazor 快速上手指南

    Ant Design of Blazor 是基于 Ant Design 规范、适配 Blazor Server/WASM 的 UI 组件库;需通过 NuGet 安装、Program.cs 注册服务、引入 CSS 样式,并在 Razor 页面中使用 @using AntDesign 和 等组件快速开发…

    2025年12月17日
    000
  • C#如何进行数据库分片 ShardingSphere-Proxy .NET客户端用法

    ShardingSphere-Proxy 作为兼容 MySQL/PostgreSQL 协议的透明代理,.NET 应用只需使用 MySqlConnector 或 Npgsql 等标准 ADO.NET 驱动连接其地址(如 127.0.0.1:3307),即可透明执行分片路由,无需官方 SDK 或修改业务…

    2025年12月17日
    000
  • C#如何使用nameof表达式 C# nameof运算符使用技巧

    nameof 是 C# 6.0 引入的编译时运算符,将标识符转换为字符串字面量,支持重构、避免拼写错误,适用于变量、属性、方法、类型等,但不支持表达式或动态名称。 nameof 是 C# 6.0 引入的编译时运算符,它不执行任何运行时操作,只在编译期将标识符(如变量名、方法名、属性名、类型名等)转换…

    2025年12月17日
    000
  • C#如何实现分布式锁 Redis分布式锁C#实现方法

    C#中实现Redis分布式锁需用SET命令原子加锁并设唯一value,通过Lua脚本安全解锁防误删,配合Watchdog机制自动续期,再辅以重连、重试、日志等生产级保障。 在C#中实现Redis分布式锁,核心是利用Redis的SET命令原子性设置带过期时间的key,并配合唯一value(如GUID)…

    2025年12月17日
    000
  • C#怎么实现单例模式 C#设计模式之单例实现方法

    推荐使用Lazy实现单例模式,线程安全且支持延迟初始化;其次可选静态构造函数方式(非延迟);DCL仅用于旧框架兼容。需注意避免滥用、优先考虑DI容器替代。 在C#中实现单例模式,核心是确保一个类只有一个实例,并提供全局访问点。最常用、最推荐的是静态构造函数 + 私有静态只读字段方式(线程安全、简洁、…

    2025年12月17日
    000
  • Blazor 弹窗(Modal)怎么实现

    Blazor纯C#实现Modal弹窗无需JS,核心是状态驱动显隐、防滚动、点击遮罩/ESC关闭、焦点管理及可配置样式;通过RenderFragment支持嵌套内容,配合CSS遮罩与动画,兼顾可访问性与体验。 Blazor 实现弹窗(Modal)不依赖 JS,纯 C# + Razor 就能搞定,核心是…

    2025年12月17日 好文分享
    000
  • C#怎么获取当前路径 C#获取程序运行目录方法

    最常用且安全的方式是使用AppDom%ignore_a_1%n.CurrentDomain.BaseDirectory获取exe所在目录;Environment.CurrentDirectory返回当前工作目录但可能变化;跨平台推荐AppContext.BaseDirectory或Assembly.…

    2025年12月17日
    000
  • C#怎么创建抽象类 C# abstract class与virtual方法

    抽象类用abstract声明,不可实例化,只能继承;可含已实现成员和必须由子类重写的abstract成员;含abstract成员的类必须声明为abstract;子类须override所有abstract成员,除非自身也声明为abstract。 在C#中,抽象类用 abstract 关键字声明,不能被…

    2025年12月17日
    000
  • Blazor怎么进行组件间通信 Blazor组件参数传递方法

    Blazor组件通信核心是参数传递、状态管理与事件回调:父子用[Parameter]和EventCallback;祖孙用CascadingParameter;无关系组件用StateContainer;路由通信用NavigationManager。 Blazor 组件间通信核心靠 参数传递 + 状态管…

    2025年12月17日
    000
  • C# 如何使用MemoryStream – 在内存中进行流操作

    MemoryStream 是 C# 中基于内存的流实现,继承自 Stream,用于临时存储、序列化、加密等场景,可提升性能;需注意内存占用、位置重置和及时释放资源。 在 C# 中,MemoryStream 是一种基于内存的流实现,允许你在不涉及磁盘或网络的情况下对数据进行读写操作。它继承自 Stre…

    2025年12月17日
    000
  • Blazor 怎么集成 Google 登录

    Blazor集成Google登录分WebAssembly和Server两类:WASM独立模式前端直连OAuth,需引入认证包、配置ClientId及回调地址;Server模式依赖后端中间件,需注册AddGoogle并启用UseAuthentication/UseAuthorization。 Blaz…

    2025年12月17日
    000
  • C# 信号量(Semaphore)的应用 – 控制对资源的并发访问数

    应使用 SemaphoreSlim 控制并发许可数而非线程数,适用于限流场景;需用 try/finally 或 C#12+ using 确保 Release,避免许可泄露。 信号量(Semaphore)在 C# 中是用来限制同时访问某资源的线程数量的同步原语。它不像 lock 那样只允许一个线程进入…

    2025年12月17日
    000
  • Blazor 创建和注入 API Service 的方法

    Blazor中创建和注入API Service的核心是定义接口与实现类封装HTTP调用,通过DI注册(WebAssembly用Singleton、Server用Scoped),并在OnInitializedAsync中异步调用;需注意HttpClient配置、CORS、生命周期匹配及错误处理。 在 …

    2025年12月17日
    000
  • C# yield关键字的作用 – 实现迭代器与状态机的简便方法

    yield关键字用于声明迭代器方法,使方法能逐个提供序列元素并自动管理状态;返回类型须为IEnumerable等,编译器自动生成状态机,支持延迟计算与内存优化。 yield 关键字在 C# 中不是用来“返回值”或“跳出方法”的,而是专门用于声明迭代器方法(iterator method)——它让方法…

    2025年12月17日
    000
  • C#怎么遍历枚举 C# Enum.GetValues遍历方法

    在C#中遍历枚举最常用方式是Enum.GetValues,返回Array类型,需显式转换为具体枚举类型或使用C# 7.3+泛型重载;配合GetNames可获取名称与值;Flags枚举需手动位运算生成组合值。 在 C# 中遍历枚举最常用、最直接的方式就是用 Enum.GetValues,它返回一个包含…

    2025年12月17日
    000
  • Blazor 怎么自定义表单验证消息

    Blazor自定义表单验证消息主要有三种方式:一是用DataAnnotations+自定义ValidationAttribute实现字段级规则;二是用EditContext.ValidationMessageStore动态添加运行时业务错误;三是手动监听EditContext事件实现复杂联动校验。 …

    2025年12月17日
    000
  • Blazor 怎么实现拖放功能

    Blazor拖放依赖HTML5 drag & drop API,需设draggable=”true”、用@ondragstart/@ondragover/@ondrop绑定事件,注意阻止默认行为、数据传递及跨平台限制。 Blazor 实现拖放功能主要靠 HTML5 原…

    2025年12月17日
    000
  • Blazor WASM AOT 提升运行时性能的方法

    AOT编译可提升Blazor WebAssembly性能,但需显式启用、精简反射依赖、优化渲染逻辑并结合Web API协同调优。 Blazor WebAssembly(WASM)启用 AOT(Ahead-of-Time)编译后,能显著减少 JIT 开销、缩短启动时间、提升执行效率。但 AOT 本身不…

    2025年12月17日
    000
  • C# For和Foreach循环的性能差异 – 遍历集合的最佳选择

    for在数组和List等支持随机访问的集合中通常更快,因无枚举器开销;foreach更安全可读,适合多数场景且不易出错。 在C#中,for 和 foreach 都能遍历集合,但性能表现并不总是一样。关键看集合类型、是否需要索引、以及是否在循环中修改集合 —— 这些因素直接影响哪种写法更高效、更安全。…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信