.NetCore中事务没有正常完成

1. 示例代码

cs 复制代码
async Task<string> FunCode()
{
    //业务代码

    using var trans = TransactionHelper.GetTransactionScope();
            
    //插入表A,A中有Name字段
    await 数据库操作1;
    await 数据库操作2;    

    trans.Complete();

    //调用其他系统接口
    await ERP.SendContent();
}

2. 代码描述

核心代码在于一个用using包起来的事务操作,后面加了一个接口调用的功能

3. 场景描述

在MES系统触发FunCode()方法时,先执行数据库操作,在执行调用ERP接口,ERP接口会立马回复,并传递A表中的Name作为参数调用MES系统另外一个接口CheckNameApi,该接口会根据Name字段来判断表中是否存在记录。

4. 异常描述

CheckNameApi中的在根据Name在A表中查数据时,无法查到。但是人为直接在数据库中是能查到的。且在对比表A插入的时间,和CheckNameApi接口调用的时间,有相差3秒。

5. 解决方案

trans.Complete();后面加上一句 trans.Dispose();

cs 复制代码
 trans.Complete();
 trans.Dispose();

6. 具体原因

母鸡。。。

相关推荐
张萌杰2 天前
深度学习的基础知识(常见名词解释)
人工智能·深度学习·机器学习·1024程序员节
开开心心就好3 天前
免费无广告卸载工具,轻便安全适配全用户
linux·运维·服务器·网络·安全·启发式算法·1024程序员节
开开心心就好4 天前
图片格式转换工具,右键菜单一键转换简化
linux·运维·服务器·python·django·pdf·1024程序员节
徐子童6 天前
网络协议---TCP协议
网络·网络协议·tcp/ip·面试题·1024程序员节
扫地的小何尚8 天前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
数据皮皮侠AI9 天前
上市公司股票名称相似度(1990-2025)
大数据·人工智能·笔记·区块链·能源·1024程序员节
开开心心就好9 天前
系统清理工具清理缓存日志,启动卸载管理
linux·运维·服务器·神经网络·cnn·pdf·1024程序员节
Evan东少12 天前
[踩坑]笔记本Ubuntu20.04+NvidiaRTX5060驱动+cuda+Pytorch+ROS/Python实现人脸追踪(环境准备)
1024程序员节
不爱编程的小陈13 天前
C/C++每日面试题
面试·职场和发展·1024程序员节
开开心心就好13 天前
右键菜单管理工具,添加程序自定义名称位置
linux·运维·服务器·ci/cd·docker·pdf·1024程序员节