spring mysql自动提交事务_Spring手动提交事务和回滚事务

1. 背景介绍

本文基于快递包裹取件(用户获取包裹并将包裹信息存储数据库)和包裹入库(快递员将包裹放入收发室并将包裹信息存储如数据库)场景,并将包裹入库信息和取件信息分别存入不同的数据库。这样当用户取件时,需要更新两个表信息(入库表中的包裹状态和取件表中插入取件信息)。

2. 问题描述

在采用SSM框架搭建后端服务时,若Service层业务逻辑较复杂,一条业务逻辑中可能会调用多个dao层更改数据库的接口。此时若采用Spring自带的@Transactional注解进行事务处理,将难以满足业务需求。正如代码块1所示:

代码块1

packet com.example.pickup;

public interface PickUpDao{

@Delete("delete from pickup where orderNum=#{orderNum}")

public int removePickUpPacket(String orderNum)

}

packet com.example.storage;

public interface StorageDao{

@Update("update storage set isPickup=false where orderNum=#{orderNum}")

public int updateStatuOfStoragePacket(String orderNum,boolean statu)

}

packet com.example.pickup;

public class PickUpServiceImpl{

@Autowired

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值