news 2026/4/23 16:09:26

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/23 11:12:33

UltraVNC完全掌握指南:5个步骤让远程控制变得简单

UltraVNC完全掌握指南&#xff1a;5个步骤让远程控制变得简单 【免费下载链接】UltraVNC UltraVNC Server, UltraVNC Viewer and UltraVNC SC | Official repository: https://github.com/ultravnc/UltraVNC 项目地址: https://gitcode.com/gh_mirrors/ul/UltraVNC Ultr…

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

31、进程间通信(IPC)详解

进程间通信(IPC)详解 1. 进程间通信概述 进程间通信(IPC)是操作系统提供的一系列机制,用于实现同一系统内进程和线程之间的数据共享(如共享内存段)、信息与数据交换(如消息队列)以及对共享资源访问的同步(如信号量)。与基于网络的通信设施(如套接字和RPC接口)不…

作者头像 李华
网站建设 2026/4/23 6:05:39

异步调用共享MDC信息(请求id,用户信息)用于日志跟踪(登录日志)、批量生成数据、异步存储设备登录数

文章目录 I 开发设计 性能优化 异步调用共享MDC信息 MDC(Mapped Diagnostic Context) II 案例 存储设备登录数 异步存储用户登录日志 I 开发设计 本文介绍了开发设计中的性能优化和MDC信息共享方案。 在性能优化方面 建议数据库层面创建查询索引并避免循环操作 代码层面采用…

作者头像 李华
网站建设 2026/4/23 12:34:36

Oh My Zsh主题美化:打造高效又美观的命令行工作环境

Oh My Zsh主题美化&#xff1a;打造高效又美观的命令行工作环境 【免费下载链接】ohmyzsh 项目地址: https://gitcode.com/gh_mirrors/ohmy/ohmyzsh 在数字时代&#xff0c;命令行界面早已不再是程序员的专属工具&#xff0c;而是高效工作者的得力助手。一个精心设计的…

作者头像 李华
网站建设 2026/4/23 12:46:30

Flux.1 Kontext Dev完整部署教程:从零开始构建AI图像生成环境

Flux.1 Kontext Dev完整部署教程&#xff1a;从零开始构建AI图像生成环境 【免费下载链接】FLUX.1-Kontext-dev 项目地址: https://ai.gitcode.com/hf_mirrors/black-forest-labs/FLUX.1-Kontext-dev 作为AI图像生成领域的革命性突破&#xff0c;Flux.1 Kontext Dev开源…

作者头像 李华
网站建设 2026/4/23 0:35:01

4大实战技巧解决语音识别与图像分析的性能瓶颈

4大实战技巧解决语音识别与图像分析的性能瓶颈 【免费下载链接】google-cloud-go Google Cloud Client Libraries for Go. 项目地址: https://gitcode.com/GitHub_Trending/go/google-cloud-go 还在为AI服务的响应延迟和准确率问题头疼吗&#xff1f;&#x1f914; 在真…

作者头像 李华