Dapper怎么使用Dapper.Contrib进行CRUD Dapper.Contrib快速操作指南

幻夢星雲
发布: 2025-12-19 09:29:50
原创
639人浏览过
Dapper.Contrib 可实现免手写 SQL 的高性能 CRUD,需安装 Dapper 和 Dapper.Contrib 包、引入命名空间、实体标记 [Table] 和 [Key] 特性,并调用 Get/GetAll/Insert/Update/Delete 等扩展方法。

dapper怎么使用dapper.contrib进行crud dapper.contrib快速操作指南

直接用 Dapper.Contrib 就能绕过手写 SQL,实现接近原生 Dapper 性能的 CRUD 操作,关键在实体标记和方法调用——不复杂但容易忽略细节。

安装与基础引用

先通过 NuGet 安装两个包(缺一不可):

  • dotnet add package Dapper
  • dotnet add package Dapper.Contrib

代码中必须同时引入命名空间:

using Dapper;
using Dapper.Contrib.Extensions;

实体类要加特性标记

Dapper.Contrib 不靠约定猜表名或主键,而是依赖特性显式声明。最简配置示例如下:

[Table("Users")]<br>public class User<br>{<br>    [Key]<br>    public int Id { get; set; }<br>    public string Name { get; set; }<br>    public DateTime CreatedAt { get; set; }<br>}
登录后复制

注意点:

  • [Table] 必须指定数据库表名,不能省略
  • [Key] 标识主键字段,仅一个字段可用;若主键非自增或需手动赋值,可加 [ExplicitKey]
  • [Computed] 用于数据库计算列(如 GETDATE()),插入/更新时自动跳过
  • 不加任何标记的属性默认参与插入和更新

四大核心方法直接上手

所有方法都是 IDbConnection 的扩展,连接打开后即可调用:

Dream Machine
Dream Machine

Dream Machine 是由 Luma AI 开发的一款 AI 视频生成工具,可以快速将文本和图像转换为高质量的视频内容。

Dream Machine 165
查看详情 Dream Machine
  • 查单条connection.Get<user>(1)</user> → 等效 SELECT * FROM Users WHERE Id = @Id
  • 查全部connection.GetAll<user>()</user> → 返回 IEnumerable<user></user>
  • 插一条int newId = connection.Insert(new User { Name = "Alice" }); → 自增主键自动返回,非自增则返回影响行数
  • 删/改connection.Update(user)connection.Delete(user),都按 [Key] 字段匹配操作

支持事务传参:connection.Insert(user, transaction),适合多步一致性操作。

批量操作与常见避坑

批量插入、更新、删除也内置支持:

  • connection.Insert(new[] { u1, u2, u3 }) → 一次插入多条,返回主键数组
  • connection.Update(new[] { u1, u2 }) → 按主键批量更新

容易出错的地方:

  • 实体没加 [Table][Key] → 运行时报 InvalidOperationException: No key defined
  • 主键字段名不是 Id 且未标 [Key] → 查不到、插不进
  • Get<t>(id)</t> 但传入的是字符串或 Guid 类型 → 确保类型和数据库字段一致

基本上就这些。

以上就是Dapper怎么使用Dapper.Contrib进行CRUD Dapper.Contrib快速操作指南的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号