news 2026/6/23 19:01:13

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/22 18:34:22

VeraCrypt终极指南:5分钟掌握磁盘加密完整流程

VeraCrypt终极指南&#xff1a;5分钟掌握磁盘加密完整流程 【免费下载链接】VeraCrypt Disk encryption with strong security based on TrueCrypt 项目地址: https://gitcode.com/GitHub_Trending/ve/VeraCrypt VeraCrypt作为TrueCrypt的继任者&#xff0c;提供了企业级…

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

ENSP抓包分析GPT-SoVITS API通信数据格式

ENSP抓包分析GPT-SoVITS API通信数据格式 在智能语音系统日益普及的今天&#xff0c;越来越多的企业和开发者开始将AI语音合成技术集成到实际业务中。然而&#xff0c;当模型从本地训练环境走向服务化部署时&#xff0c;一个常被忽视的问题浮出水面&#xff1a;API接口到底在“…

作者头像 李华
网站建设 2026/6/23 2:56:36

37、Solaris 文件与文件 I/O 深入解析

Solaris 文件与文件 I/O 深入解析 1. 高效的文件 I/O 操作 传统的文件读写操作通常使用 lseek() 和 read() 系统调用组合来实现从特定偏移位置开始读写,但这种方式需要两个系统调用。而在 Solaris 系统中, pread(2) 和 pwrite(2) 系统调用则允许仅通过一个系统调用…

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

45、内核可调参数、开关和限制及虚拟地址映射详解

内核可调参数、开关和限制及虚拟地址映射详解 1. 内核可调参数概述 内核可调参数是可以设置的内核变量,传统上被称为内核可调参数。这些参数的值在 /etc/system 文件中设置,系统在启动时会读取该文件,因此对该文件所做的任何更改都需要重启系统才能生效。 可设置的内核…

作者头像 李华
网站建设 2026/6/14 21:41:16

AI市场舆情分析与量化风险:超越预测的2025年AI决策之道

在信息爆炸与市场瞬息万变的2025年&#xff0c;企业决策应该更依赖高管团队的直觉经验&#xff0c;还是能够拥抱一种全新的智能范式&#xff1f;这已不再是一个遥远的选择题&#xff0c;而是摆在每一位决策者面前的现实挑战。当市场的反馈周期从季度、月度被压缩至以天甚至小时…

作者头像 李华
网站建设 2026/6/22 16:41:43

Ivy统一AI框架:5步实现多框架代码无缝转换

在AI开发领域&#xff0c;你是否曾因不同框架间的代码迁移而头疼&#xff1f;Ivy统一AI框架正是为解决这一痛点而生。这个创新的开源项目让机器学习代码可以在PyTorch、TensorFlow、JAX、NumPy等主流框架间自由转换&#xff0c;真正实现了"一次编写&#xff0c;到处运行&q…

作者头像 李华