我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SpringBoot中@Transiactional注解没有效果的解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SpringBoot中@Transiactional注解没有效果的解决

SpringBoot @Transiactional注解没有效果

背景

数据库为mysql

问题

使用SpringBoot操作数据库插入两条数据,service层的方法出现了异常,按理说两条数据都该插不进去的,可以数据库中却还是有一条数据。

数据库表格式:

这里写图片描述

service层代码:


package com.example.demo.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.example.demo.domain.Girl;
import com.example.demo.repository.GirlRepository;
@Service
public class GirlService {
    @Autowired
    private GirlRepository girlRepository;
    @Transactional
    public void transiactionTest() {
        Girl g1 = new Girl();
        g1.setAge(33);
        g1.setCupSize("B");
        girlRepository.save(g1);
        Girl g2 = new Girl();
        g2.setAge(33);
        g2.setCupSize("FFFFF");  // 长度和数据库的长度不符,会出异常
        girlRepository.save(g2);
    }
}

启动SpringBoot后,访问对应的方法,控制台也报错,但是表中是有一条数据的(原本是空表)。

这里写图片描述

查了查资料说的是在设计表的时候要选取的InnoDB引擎

回头看我的表引擎:

还真的是。。。。。。

解决

将数据表的引擎设置为InnoDB引擎。 然后再次执行,@Transitional注解才起了作用,数据表中没有了数据。

这里写图片描述

SpringBoot 使用Transaction注解遇到的坑

一、场景

开发一个多批次入库的功能,功能中涉及到多个表间的操作,对数据库表的操作要么同时成功,要么同时失败,不然就会存在脏数据,所以使用到了事务这个知识点()。

划重点:重要的都使用红色标出来了,大家如果不想看我废话,直接跳到红色字体即可0...0

二、Spring中使用的使用方式

1、使用传统的手动开始,手动提交事务即:beginTransaction()、commit()、rollback()等事务管理相关的方法,这就是编程式事务管理。

2、使用Transaction注解的声明式事务,将事务的开启和提交交给Spring容器完成,这个也是本次我使用的方式,简单,但是使用时需要注意很多细节。

3、基于Spring AOP的切面的事务配置(本人很少使用这个,所以本文不重点刨析该知识点,想了解的可以到其他博客进行查看)

三、使用中遇到的问题

1、使用Transaction注解时抛出异常但是事务不起作用,异常时事务没有进行回滚?

答:经过排查,查询在开启事务的方法中最外层使用了try...catch进行了异常的捕获,因此抛出的异常本捕获了,切面无法捕获到异常,所以不会进行回滚。

解决:

(1) 手动指定切面捕获的异常类型(因为默认情况下只会在RuntimeExceptionimeException情况下才会进行事务的回滚),方式:@Transaction(rollbcackFor=Exception.class)

(2) 在catch中手动抛出一个运行时异常即:throw new RuntimeException();

(3) 如果需要在事务回滚时,给调用当前方法的调用者返回错误信息的话,用第二种方案就是不行的,因为抛出异常后的语句时不会执行的,包括return后面的语句,所以,此时可以手动进行事务回滚的语句调用即:TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();

2、刚插入的数据,无法马上查询到?

答: 这个问题是个大坑,整整苦恼了我两天(可能是之前使用事务相关的知识比较少,所以遇到了根本就不知道是什么原因),因为项目中使用的是MybatisPlus框架,一开始便怀疑是框架的缓存问题,因为刚插入马上查询时,查询的SQL语句并没有执行,即根本没到数据库去查,但是,手动关闭了缓存之后并没起效果,最后大佬看了代码后,一眼就指出问题所在(现在不得不感慨,经验时多么重要)。

要解决这个问题,首先要知道使用Transaction是怎么进行事务增强的,说白了,是通过生成代理对象进行切面注入的,当前对象并没有增强的作用,刚开始我插入和查询的方法都是写在一个service中,然后使用this调用这些方法,而this表示的是当前的service对象,所以这些方法根本就不在当前的事务中,因为刚插入的数据无法马上查询到0....0(我踩的大坑希望大家不要再踩了,太难受了..)

解决方法:说了这么多废话,现在知道问题产生的原因,所以就好解决了:

(1) 将所有的数据库操作方法抽取到另外一个Service对象中,然后通过@Autowire注入调用即可。

(2) 自己注入自己的对象即当前Service为A,可以直接使用:@Autowire private A a; 然后通过a调用相关数据库操作的方法(注意不要使用this,使用this的话无效),@Autowire private A a这句话实际上返回的是当前Service的代理对象,但特别需要注意的是:所有操作数据库相关的方法,访问权限都需改成public,不然会出现mapper和service注入为null---这个是个大坑,具体原因还不知道(这个方式推荐使用)

(3) 使用:((A) AopContext.currentProxy()).方法名()进行调用(听说这个方式在打包发布的时候会出现问题,本次没有试过这个方式,所以不推荐)

总结:

经验就是一个积累的过程,没有谁能够一步登天,所以脚踏实地才是成功的秘诀。本文只是本人在使用事务知识是遇到的问题的总结,希望能给大家一个参考,也希望大家多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SpringBoot中@Transiactional注解没有效果的解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

react引入css没有效果如何解决

本文小编为大家详细介绍“react引入css没有效果如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“react引入css没有效果如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。react引入css没
2023-07-04

css导入成功但没有效果的解决方法

这篇文章给大家分享的是有关css导入成功但没有效果的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。css导入成功但没有效果的解决办法:1、打开网页调试工具,根据显示错误进行修改;2、查看link标签的“r
2023-06-14

JPA默认值设置没有效果怎么解决

这篇文章主要介绍“JPA默认值设置没有效果怎么解决”,在日常操作中,相信很多人在JPA默认值设置没有效果怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JPA默认值设置没有效果怎么解决”的疑惑有所帮助!
2023-06-25

idea导入springboot项目没有maven的解决

这篇文章主要介绍了idea导入springboot项目没有maven的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-17

wlan没有有效的ip配置如何解决

这篇文章主要介绍了wlan没有有效的ip配置如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇wlan没有有效的ip配置如何解决文章都会有所收获,下面我们一起来看看吧。wlan没有有效的ip配置:1、首先点
2023-07-02

如何解决SEM推广怎么做都没有效果的问题

本篇内容介绍了“如何解决SEM推广怎么做都没有效果的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  第一、关键词较差  这个问题其实很
2023-06-13

SpringBoot中常用的注解有哪些

这篇文章主要介绍了SpringBoot中常用的注解有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、@SpringBootApplication此注解是Spring B
2023-06-21

idea中运行程序没有结果如何解决

如果在IDE中运行程序没有结果,可能是由于以下几个原因导致的:1. 代码中存在错误:检查代码是否有语法错误或逻辑错误。IDE通常会标记代码中的错误,你可以根据提示进行修正。2. 输入错误或无输入:检查代码中是否有用户输入或读取文件等操作,确
2023-09-07

电脑注册表中没有msahci选项如何解决

本篇内容介绍了“电脑注册表中没有msahci选项如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.在运行窗口中直接输入regedit
2023-06-27

php如果数组中没有数据库怎么解决

php如果数组中没有数据库的解决办法:1、创建一个PHP示例文件;2、创建MySQL数据库和到达数据库的链接,通过“mysql_connect()”函数完成,其语法为“mysql_connect(servername,username,password);”;3、将PHP文件导入数据库运行相关代码即可。
2023-05-25

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录