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

母鸡。。。

相关推荐
hazy1k1 小时前
51单片机基础-IO扩展(并转串 74HC165)
stm32·单片机·嵌入式硬件·fpga开发·51单片机·1024程序员节
unable code13 小时前
攻防世界-Misc-pdf
网络安全·ctf·misc·1024程序员节
第七序章16 小时前
【C + +】C + + 11(中)——Lambda 表达式 + 可变参数模板
c语言·c++·算法·1024程序员节
qq192572302716 小时前
23种设计模式
设计模式·1024程序员节
美狐美颜sdk18 小时前
直播美颜SDK特效功能实战:从API调用到效果调优的全过程
人工智能·1024程序员节·美颜sdk·直播美颜sdk·第三方美颜sdk
码力引擎1 天前
【零基础学MySQL】第十二章:DCL详解
数据库·mysql·1024程序员节
代码村新手1 天前
数据结构-链表
1024程序员节
第七序章1 天前
【C + +】C++11 (下) | 类新功能 + STL 变化 + 包装器全解析
c语言·数据结构·c++·人工智能·哈希算法·1024程序员节
努力学习的小廉2 天前
初识MYSQL —— 基本查询
数据库·mysql·1024程序员节
码力引擎2 天前
【零基础学MySQL】第四章:DDL详解
数据库·mysql·1024程序员节