.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. 具体原因

母鸡。。。

相关推荐
Joeysoda3 天前
Java数据结构 (从0构建链表(LinkedList))
java·linux·开发语言·数据结构·windows·链表·1024程序员节
清风-云烟5 天前
使用redis-cli命令实现redis crud操作
java·linux·数据库·redis·spring·缓存·1024程序员节
Joeysoda6 天前
Java数据结构 (链表反转(LinkedList----Leetcode206))
java·linux·开发语言·数据结构·链表·1024程序员节
比特在路上6 天前
StackOrQueueOJ3:用栈实现队列
c语言·开发语言·数据结构·1024程序员节
0xCC说逆向7 天前
Windows图形界面(GUI)-QT-C/C++ - Qt键盘与鼠标事件处理详解
c语言·开发语言·c++·windows·qt·win32·1024程序员节
明明真系叻9 天前
2025.1.18机器学习笔记:PINN文献精读
人工智能·笔记·深度学习·机器学习·1024程序员节
0xCC说逆向9 天前
Windows图形界面(GUI)-QT-C/C++ - Qt List Widget详解与应用
c语言·开发语言·c++·windows·qt·win32·1024程序员节
明明真系叻11 天前
2025.1.12机器学习笔记:GAN文献阅读
人工智能·笔记·深度学习·机器学习·1024程序员节
比特在路上12 天前
OJ12:160. 相交链表
c语言·数据结构·算法·链表·1024程序员节
earthzhang202113 天前
《深入浅出HTTPS》读书笔记(28):DSA数字签名
开发语言·网络协议·算法·https·1024程序员节