news 2026/6/10 17:16:42

ABP框架+Dapper执行原生sql

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ABP框架+Dapper执行原生sql

之前发表一个ABP框架+EF执行原生sql,后来自己想了想安装Dapper,用Dapper执行原生sql也可以,并且效率会比EF优一点。

一、首先安装Dapper

有多种方案安装,nuget包安装,或者执行命令

dotnet add package Dapper

二、项目中使用

注意在当前文件引用Dapper

using Dapper;

注入你要操作表的仓储

private readonly IRepository<WorkOrder, Guid> _repository; public WorkOrderExtensionService( IRepository<WorkOrder, Guid> repository){ _repository = repository; }

写好自己要的sql业务,然后通过Dapper执行

var parameters = new { TenantId = _currentTenant.Id, SkipCount = input.SkipCount, PageSize = input.MaxResultCount, OrderId = orderId, OrderNo = input.OrderNo, }; var sql = @" select w.SeriesNo,w.Seq, CASE WHEN r.SnCode is null THEN 0 ELSE 1 END `State` from JG_WorkOrderTasks w left join ( select SnCode from JG_WorkOrderDistributionRecords where WorkOrderNumber = @OrderNo and DispatchStatus = 1 group by SnCode ) r on w.SeriesNo = r.SnCode where w.OrderId = @OrderId and IsDeleted = 0 and TenantId = @TenantId order by `State`, Seq limit @PageSize offset @SkipCount"; var countSql = @" select count(0) from JG_WorkOrderTasks where OrderId = @OrderId and IsDeleted = 0 and TenantId = @TenantId"; var dbContext = await _repository.GetDbContextAsync(); var connection = dbContext.Database.GetDbConnection(); if (connection.State != ConnectionState.Open) await connection.OpenAsync(); var list = await connection.QueryAsync(sql, parameters); var snCount = await connection.ExecuteScalarAsync<int>(countSql, parameters); List<HitList> resData = list.Select(c => new HitList { SnCode = c.SeriesNo, Seq = c.Seq, HitState = c.State == 0 ? "未打标" : "已打标" }).ToList();

三、解析一下上面代码

数据库上下文和连接

var dbContext = await _repository.GetDbContextAsync(); var connection = dbContext.Database.GetDbConnection(); if (connection.State != ConnectionState.Open) await connection.OpenAsync();
  • 通过_repository获取数据库上下文并获取数据库连接。
  • 检查连接状态,如果未打开,则异步打开连接。

执行查询

var list = await connection.QueryAsync(sql, parameters); var snCount = await connection.ExecuteScalarAsync<int>(countSql, parameters);
  • 使用 Dapper 的QueryAsync方法执行主查询,返回一个结果列表。
  • 使用ExecuteScalarAsync<int>执行计数查询,返回总记录数。

使用 Dapper 作为 ORM,使得 SQL 查询更为简洁高效,同时通过参数化查询提高了安全性(防止 SQL 注入)。整体结构清晰,符合常见的 .NET 开发模式。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 15:46:42

创建一个大BOSS!(7)完善一下招式1,并制作招式2

在上一期中&#xff0c;会出现BOSS虽然面朝向我们但是发射的武器却没朝向我们。我们来完善一下。 打开招式1的活动蓝图获取BOSS向前的向量直接拉到旋转那就行然后我们来做招式2&#xff0c;打开行为树&#xff0c;找到招式2部分修改参数然后我们做一个任务去更新我们最后攻击的…

作者头像 李华
网站建设 2026/6/10 13:52:07

终极C语言HTML5解析方案:gumbo-parser完全指南

终极C语言HTML5解析方案&#xff1a;gumbo-parser完全指南 【免费下载链接】gumbo-parser An HTML5 parsing library in pure C99 项目地址: https://gitcode.com/gh_mirrors/gum/gumbo-parser 在Web开发领域&#xff0c;HTML解析是数据处理的基础环节。对于C语言开发者…

作者头像 李华
网站建设 2026/6/10 2:21:53

HULK云数据库:TiDB集群多机房高可用

一、介绍TiDB作为一款分布式、金融级高可用数据库&#xff0c;数据采用多副本存储&#xff0c;数据副本通过 Multi-Raft 协议同步事务日志&#xff0c;多数派写入成功事务才能提交&#xff0c;确保数据强一致性且少数副本发生故障时不影响数据的可用性。还可以按需配置副本地理…

作者头像 李华
网站建设 2026/6/9 22:12:18

AI营销内容生产神器,2025年谁是卷王?

2025年&#xff0c;内容营销的战场硝烟弥漫&#xff0c;短视频平台早已从过去的“可选项”演变为企业触达客户的“主动脉”。然而&#xff0c;在这片流量的红海中&#xff0c;绝大多数企业却陷入了集体性的“内容失语症”。创意团队灵感枯竭&#xff0c;生产效率在海量的内容需…

作者头像 李华
网站建设 2026/6/10 14:40:28

41、深入解析文件系统:fsflush 与 UFS 的奥秘

深入解析文件系统:fsflush 与 UFS 的奥秘 1. 文件系统刷新守护进程 fsflush 在文件系统框架中,fsflush 进程扮演着重要的角色。它的主要任务是定期将修改过的页面写入磁盘。具体来说,fsflush 进程会扫描物理内存,查找脏页(即已修改但尚未写入磁盘的页面)。一旦找到脏页…

作者头像 李华
网站建设 2026/6/9 21:57:27

46、进程文件系统实用工具与系统相关知识解析

进程文件系统实用工具与系统相关知识解析 1. 示例进程文件系统实用工具展示 在系统操作中,我们可以使用 msacct 工具来对命令进行微状态统计。例如,执行 $ msacct ls -lR 命令后,会输出一系列信息,包括文件和目录的详细信息,以及使用计数器和状态时间的统计结果。以…

作者头像 李华