Dapper介绍及特性

一、Dapper介绍及特性
Dapper是一个.NET平台上的轻量级对象关系映射(ORM)工具,它通过扩展IDbConnection接口,提供了一系列的扩展方法来执行SQL查询并将结果映射到.NET对象中。Dapper以其高性能和简单易用著称,特别适合需要快速开发和对性能有较高要求的场景。
Dapper的主要特点
- 高性能:Dapper执行的是原始SQL查询,避免了复杂的查询生成过程,因此性能接近于手写ADO.NET代码。
- 简单易用:Dapper的API简洁直观,学习曲线低,可以快速上手。
- 轻量级:没有复杂的上下文管理和变化跟踪机制,减少了性能开销。
- 参数化查询:支持参数化查询,有效防止SQL注入攻击。
- 事务支持:支持事务处理,确保数据操作的一致性。
- 灵活性:允许开发者完全控制SQL语句,实现更复杂的查询逻辑。
Dapper的基本用法
- 查询数据:使用
Query方法执行SQL查询并返回结果集。 - 插入数据:使用
Execute方法执行插入操作。 - 更新数据:使用
Execute方法执行更新操作。 - 删除数据:使用
Execute方法执行删除操作。 - 存储过程:通过指定
commandType: CommandType.StoredProcedure来执行存储过程。
Dapper的高级功能
- 多映射:支持多表查询并将结果映射到多个对象。
- 动态对象:支持动态对象,适用于不确定返回结构的查询。
- 缓存功能:内置简单的缓存功能,可以提高查询性能。
Dapper的使用场景
Dapper适合于需要高效数据访问的应用场景,尤其是在已有数据库项目中快速集成和使用。它的优势在于高性能、简单易用和灵活性,但不适合复杂的业务逻辑处理场景,因为没有复杂的对象关系映射和LINQ支持。

二、安装Dapper
Dapper可以通过NuGet包管理器安装:
PM> Install-Package Dapper
Dapper的工作原理
Dapper通过扩展IDbConnection接口,提供了Query、Execute、QueryFirst、QueryFirstOrDefault、QuerySingle、QuerySingleOrDefault、QueryMultiple等一系列扩展方法来执行数据库操作。它缓存了SQL查询计划,减少了SQL解析和执行的开销。
Dapper与其他ORM框架的比较
与Entity Framework、NHibernate等ORM框架相比,Dapper在性能、易用性和配置灵活性方面具有优势,但在映射能力和LINQ支持方面则较为简单。与ADO.NET相比,Dapper提供了更简单的API和对象映射功能,但性能相当。
总的来说,Dapper是一个在性能和易用性之间找到平衡点的ORM框架,适合于多种数据库操作需求。
GitHub - DapperLib/Dapper: Dapper - a simple object mapper for .Net
https://github.com/DapperLib/Dapper
三、Dapper性能优势
Dapper 是一个高性能的微 ORM,它通过提供一组映射和查询扩展方法来使用。与 Entity Framework 或 NHibernate 这样的全功能 ORM 相比,Dapper 的性能优势主要体现在以下几个方面:
-
执行效率:Dapper 的性能接近原生 ADO.NET,因为它不会像其他 ORM 那样生成额外的查询来跟踪更改或处理延迟加载 。
-
轻量级:Dapper 作为一个微型 ORM,它不需要复杂的配置和上下文管理,这减少了内存消耗和性能开销 。
-
直接执行 SQL:Dapper 允许开发者编写原始 SQL 语句,这意味着可以精确控制查询和优化性能,避免了 ORM 自动生成的低效 SQL 语句 。
-
映射缓存:Dapper 能够缓存 SQL 查询结果的映射信息,这样在后续的查询中可以快速反序列化结果,提高了重复查询的性能 。
-
批量操作:Dapper 支持批量插入和更新操作,这些操作通常比逐条处理数据要快得多 。
-
避免不必要的对象创建:Dapper 只有在必要时才会创建对象,这意味着它能够最小化内存中对象的数量,从而提高性能 。
-
扩展性:Dapper 允许开发者通过扩展方法来增加新功能,而不需要改动核心库,这样可以保持库的轻量级和高性能 。
-
多数据库支持:Dapper 支持多种数据库系统,开发者可以根据项目需求选择最合适的数据库,而不会因为 ORM 的限制而牺牲性能 。
-
控制权:Dapper 提供了对 SQL 语句的完全控制权,开发者可以优化查询以适应特定的数据库和索引设计,从而获得更好的性能 。

四、Dapper支持哪些数据库
- SQL Server:通过使用
System.Data.SqlClient.SqlConnection来连接SQL Server数据库。 - MySQL:通过使用
MySql.Data.MySqlClient.MySqlConnection来连接MySQL数据库。 - PostgreSQL:通过使用
Npgsql.NpgsqlConnection来连接PostgreSQL数据库。 - SQLite:通过使用
System.Data.SQLite.SQLiteConnection来连接SQLite数据库。 - Oracle:通过使用
Oracle.ManagedDataAccess.Client.OracleConnection来连接Oracle数据库。 - IBM DB2:可以通过使用
System.Data.OleDb.OleDbConnection(或其他相应的DB2连接类)来连接IBM DB2数据库。
五、示例代码
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using Dapper;public class Program
{private static readonly string ConnectionString = "your_connection_string_here";public static void Main(){// 查询示例var users = QueryUsers();Console.WriteLine("查询到的用户:");foreach (var user in users){Console.WriteLine($"ID: {user.Id}, Name: {user.Name}");}// 插入示例var newUser = new User { Name = "John Doe" };int affectedRows = InsertUser(newUser);Console.WriteLine($"插入新用户,影响行数:{affectedRows}");// 更新示例newUser.Name = "Jane Doe";affectedRows = UpdateUser(newUser);Console.WriteLine($"更新用户,影响行数:{affectedRows}");// 删除示例affectedRows = DeleteUser(newUser.Id);Console.WriteLine($"删除用户,影响行数:{affectedRows}");}public static List<User> QueryUsers(){using (var connection = new SqlConnection(ConnectionString)){return connection.Query<User>("SELECT * FROM Users").ToList();}}public static int InsertUser(User user){using (var connection = new SqlConnection(ConnectionString)){string sql = "INSERT INTO Users (Name) VALUES (@Name);";return connection.Execute(sql, user);}}public static int UpdateUser(User user){using (var connection = new SqlConnection(ConnectionString)){string sql = "UPDATE Users SET Name = @Name WHERE Id = @Id;";return connection.Execute(sql, user);}}public static int DeleteUser(int id){using (var connection = new SqlConnection(ConnectionString)){string sql = "DELETE FROM Users WHERE Id = @Id;";return connection.Execute(sql, new { Id = id });}}
}public class User
{public int Id { get; set; }public string Name { get; set; }
}相关文章:
Dapper介绍及特性
一、Dapper介绍及特性 Dapper是一个.NET平台上的轻量级对象关系映射(ORM)工具,它通过扩展IDbConnection接口,提供了一系列的扩展方法来执行SQL查询并将结果映射到.NET对象中。Dapper以其高性能和简单易用著称,特别适合…...
LeetCode 149. 直线上最多的点数
LeetCode 149. 直线上最多的点数 给你一个数组 points ,其中 points[i] [xi, yi] 表示 X-Y 平面上的一个点。求最多有多少个点在同一条直线上。 示例 1: 输入:points [[1,1],[2,2],[3,3]] 输出:3 示例 2: 输入&…...
案例研究丨国控星鲨利用DataEase释放数据潜能,重塑业务视野
国药控股星鲨制药(厦门)有限公司(以下简称为国控星鲨)始创于1952年,前身为厦门鱼肝油厂,距今已经有70余年历史,是国家商务部认定的“中华老字号”企业。2011年,国药控股与厦门轻工集…...
网络基础概念和 socket 编程
网络基础概念和 socket 编程 学习目标: 了解 OSI 七层模型、TCP/IP 四层模型结构了解常见的网络协议格式掌握网络字节序和主机字节序之间的转换理解 TCP 服务器端通信流程理解 TCP 客户端通信流程实现 TCP 服务器端和客户端的代码 推荐一个非常好的学习资料仓库 协…...
TypeScript 中的接口、泛型与自定义类型
TypeScript 是一种超集语言,它为 JavaScript 添加了静态类型检查。通过 TypeScript,开发者可以获得更好的工具支持,并且能够编写出更加健壮的代码。本文将探讨 TypeScript 中的几个关键特性:接口、泛型以及如何创建自定义类型。 …...
常州威雅学校:跟随这场音乐盛宴,溯回她的音乐之路
时同学 常州威雅2021届毕业生 英国皇家北方音乐学院 钢琴系 西太湖畔清凉的晚风送来阵阵悦耳的钢琴声,时同学在母校的个人钢琴独奏悄然拉开序幕。这是她自毕业三年后,在常州威雅的首场钢琴独奏会。 随着第一个音符落下,她用手指在黑白键盘…...
【YashanDB知识库】由于hist_head$中analyze time小于tab$中analyze time导致的sql语句执行慢
本文内容来自YashanDB官网,具体内容请见https://www.yashandb.com/newsinfo/7459465.html?templateId1718516 问题现象 某局点yashandb cpu使用率100%,经线上分析是由于几个sql执行慢,其中一个sql为简单的单行等值绑定变量过滤排序。 经分…...
【有啥问啥】深度理解主动学习:机器学习的高效策略
深度理解主动学习:机器学习的高效策略 在大数据时代,数据量的爆炸性增长与有限的标注资源之间的矛盾日益凸显。如何高效地利用标注资源来训练高质量的模型,成为了机器学习领域亟待解决的问题。主动学习(Active Learning, AL&…...
智能守护者X100 - 自动化生产线智能机器人安全监控管理系统
1.产品介绍 产品名称: 智能守护者X100 - 自动化生产线智能机器人安全监控管理系统 主要功能: 全方位实时监控:智能守护者X100采用高清摄像头与红外夜视技术,实现对自动化生产线及智能机器人的360无死角监控。系统能自动识别并追踪生产线上的机器人活动轨迹,确保生产安全…...
harmonyos面试题
你在项目中用过线程通信吗,线程是怎么进行通信的? 页面的生命周期有哪些? UAbility的生命周期呢? 你在项目中使用首选项主要用来数什么 组件通信的方式有息些 弹室UI是怎么在页面UI中使用的 常用的修饰符有愿些介绍一下 缓冲区是什么与16进制和数组有什么关…...
神经网络介绍及其在Python中的应用(一)
作者简介:热爱数据分析,学习Python、Stata、SPSS等统计语言的小高同学~ 个人主页:小高要坚强的博客 当前专栏:Python之机器学习 本文内容:神经网络介绍及其在Python中的线性回归应用 作者“三要”格言:要坚…...
数据流处理技术与Flink框架
一数据流 数据流定义: 数据流(Data Stream)是指数据以连续不断的方式到达和处理的序列。在现实世界中,许多数据来源都是以流的形式存在,比如: 1. 用户行为:用户在网站上的点击流、移动应用中…...
qt中QTatlewidget类常用操作表格的函数有哪些?
在Qt中,QTableWidget 类提供了丰富的函数来操作表格数据。以下是一些常用的操作表格的函数: 1. 初始化与配置 构造函数:QTableWidget(int rows, int columns, QWidget *parent nullptr):创建一个指定行数和列数的表格控件。设置…...
Linux上的C/C++编程
Linux上的C/C编程 yum软件包管理器Linux编辑器-vimvim命令模式指令集vim末行模式指令集 gcc/g的使用Linux自动化编译工具-make/MakefileLinux调试器-gdb调试命令 多人合作工具git yum软件包管理器 yum 是Linux上常用的包管理器,类似于Windows上的“应用商店”。 语…...
注意 秋季饮酒的正确打开方式
选择合适的白酒1.秋季气候干燥,适合选择一些口感醇厚、温润的白酒。比如酱香型白酒,它具有浓郁的香气和醇厚的口感,能在秋季给你带来温暖的感觉。2.浓香型白酒也是不错的选择,香气扑鼻,口感绵甜,能为秋季增…...
Python如何配置环境变量详解
一、概述 前提:已安装 Python,如下图: 1.1 检查是否已配置成功(选) 1 2 3 4 5 1. 打开运行窗口 (1) 快捷键 : Win r,并输入 cmd (2) 直接输入: Python 2. 若有下列提示,即为 安装成功…...
Linux驱动开发(速记版)--并发与竞争
第十八章 并发与竞争 18.1 并发与竞争 18.1.1 并发 早期计算机 CPU单核心时,由于 CPU执行速度快于I/O操作,常因等待 I/O而空闲。 为提高 CPU利用率,引入了并发执行理论。并发通过算法在CPU执行I/O等待时切换至其他任务,使多个任…...
AI赋能,数字技术服务平台促进产业协同发展
在当今数字化浪潮席卷全球的时代,数字技术服务平台应运而生,成为推动各行业发展的强大引擎。数字技术服务平台是一个汇聚了众多先进数字技术和资源的综合性服务体系。它就像是一个功能强大的百宝箱,为用户提供了全方位的数字技术支持。 在这…...
RabbitMQ下载安装运行环境搭建
RabbitMQ运行环境搭建 1、Erlang及RabbitMQ安装版本的选择2、下载安装Erlang2.1、下载Erlang2.2、安装Erlang2.2.1、安装Erlang前先安装Linux依赖库2.2.2、解压Erlang压缩包文件2.2.3、配置2.2.4、编译2.2.5、安装2.2.6、验证erlang是否安装成功 3、RabbitMQ下载安装3.1、下载3…...
Redis过期时间删除策略详解
文章目录 Redis过期时间删除策略详解一、引言二、Redis过期键删除策略1、定时删除2、惰性删除3、定期删除 三、Redis实际采用的策略1、惰性删除Java 伪代码 2、定期删除Java 伪代码 四、总结 Redis过期时间删除策略详解 一、引言 在许多应用程序中,我们经常需要缓…...
多模态2025:技术路线“神仙打架”,视频生成冲上云霄
文|魏琳华 编|王一粟 一场大会,聚集了中国多模态大模型的“半壁江山”。 智源大会2025为期两天的论坛中,汇集了学界、创业公司和大厂等三方的热门选手,关于多模态的集中讨论达到了前所未有的热度。其中,…...
K8S认证|CKS题库+答案| 11. AppArmor
目录 11. AppArmor 免费获取并激活 CKA_v1.31_模拟系统 题目 开始操作: 1)、切换集群 2)、切换节点 3)、切换到 apparmor 的目录 4)、执行 apparmor 策略模块 5)、修改 pod 文件 6)、…...
Oracle查询表空间大小
1 查询数据库中所有的表空间以及表空间所占空间的大小 SELECTtablespace_name,sum( bytes ) / 1024 / 1024 FROMdba_data_files GROUP BYtablespace_name; 2 Oracle查询表空间大小及每个表所占空间的大小 SELECTtablespace_name,file_id,file_name,round( bytes / ( 1024 …...
Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...
蓝桥杯 2024 15届国赛 A组 儿童节快乐
P10576 [蓝桥杯 2024 国 A] 儿童节快乐 题目描述 五彩斑斓的气球在蓝天下悠然飘荡,轻快的音乐在耳边持续回荡,小朋友们手牵着手一同畅快欢笑。在这样一片安乐祥和的氛围下,六一来了。 今天是六一儿童节,小蓝老师为了让大家在节…...
MySQL用户和授权
开放MySQL白名单 可以通过iptables-save命令确认对应客户端ip是否可以访问MySQL服务: test: # iptables-save | grep 3306 -A mp_srv_whitelist -s 172.16.14.102/32 -p tcp -m tcp --dport 3306 -j ACCEPT -A mp_srv_whitelist -s 172.16.4.16/32 -p tcp -m tcp -…...
【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统
目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索(基于物理空间 广播范围)2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...
AI书签管理工具开发全记录(十九):嵌入资源处理
1.前言 📝 在上一篇文章中,我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源,方便后续将资源打包到一个可执行文件中。 2.embed介绍 🎯 Go 1.16 引入了革命性的 embed 包,彻底改变了静态资源管理的…...
中医有效性探讨
文章目录 西医是如何发展到以生物化学为药理基础的现代医学?传统医学奠基期(远古 - 17 世纪)近代医学转型期(17 世纪 - 19 世纪末)现代医学成熟期(20世纪至今) 中医的源远流长和一脉相承远古至…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
