news 2026/4/15 12:31:55

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/4/14 11:31:17

阿里开源Wan2.1-I2V:14B参数视频生成模型完整使用指南

阿里开源Wan2.1-I2V&#xff1a;14B参数视频生成模型完整使用指南 【免费下载链接】Wan2.1-I2V-14B-480P 项目地址: https://ai.gitcode.com/hf_mirrors/Wan-AI/Wan2.1-I2V-14B-480P 在2025年AI视频生成技术快速发展的背景下&#xff0c;阿里巴巴通义实验室开源了Wan2.…

作者头像 李华
网站建设 2026/4/13 5:20:43

重新定义搜索体验:语义化下拉框改造终极指南

重新定义搜索体验&#xff1a;语义化下拉框改造终极指南 【免费下载链接】bootstrap-select 项目地址: https://gitcode.com/gh_mirrors/boo/bootstrap-select 你是否厌倦了传统下拉框的机械匹配&#xff1f;当用户输入"电子产品"却找不到"手机"选…

作者头像 李华
网站建设 2026/4/15 3:51:16

5步快速上手DataEase:开源BI工具零基础入门指南

5步快速上手DataEase&#xff1a;开源BI工具零基础入门指南 【免费下载链接】DataEase 人人可用的开源 BI 工具 项目地址: https://gitcode.com/feizhiyun/dataease DataEase作为一款开源BI工具&#xff0c;以其直观的可视化分析和拖拽式操作界面&#xff0c;让数据分析…

作者头像 李华
网站建设 2026/4/13 9:20:03

35、Solaris文件与文件I/O详解

Solaris文件与文件I/O详解 1. Solaris中的文件 1.1 文件的基本定义 从广义上讲,文件是一种以字节数组形式存储数据的实体,数据从第0字节开始,一直延伸到文件末尾。文件内容可以有多种形式,如简单的文本文件、二进制可执行文件、目录文件等。Solaris支持多种类型的文件,…

作者头像 李华
网站建设 2026/4/14 1:40:02

42、Unix文件系统UFS实现详解

Unix文件系统UFS实现详解 1. UFS概述 UFS(Unix文件系统)以可加载的文件系统模块形式实现,包含vfs和vnode对象的实例。其中,UFS的vnode接口实现文件操作,而UFS的vfs接口则负责文件系统的管理。 UFS文件系统的实现可分为以下五个主要组件: - vfs对象的实例,以及用于挂…

作者头像 李华
网站建设 2026/4/12 3:57:49

GitHub热门项目EmotiVoice为何成为开发者新宠?

EmotiVoice&#xff1a;让机器“说出情感”的开源语音合成新范式 在虚拟主播直播时突然哽咽落泪&#xff0c;游戏NPC因被击败而愤怒咆哮&#xff0c;有声书朗读中语调随情节起伏波动——这些曾依赖真人配音才能实现的情感表达&#xff0c;如今正被一个名为 EmotiVoice 的开源项…

作者头像 李华