哪些异常是RuntimeException?Sql异常属于RuntimeException吗?Spring下SQL异常事务回滚

哪些异常是RuntimeException?Sql异常属于RuntimeException吗?Spring下SQL异常事务回滚更多Spring事务问题请访问链接:Spring事务回滚疑难详解一,为什么框架中根本没有对Exception的一般子类进行回滚配置,异常发生时,事务都进行了回滚,说好的只会对RuntimeException(Unchecked非受检异常)回滚呢?此时,我们就有必要了解一下,RuntimeException所包含的子类具体有哪些:这时,或许你就…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

更多Spring事务问题请访问链接:Spring事务回滚疑难详解

一,为什么框架中根本没有对Exception的一般子类进行回滚配置,异常发生时,事务都进行了回滚 ,说好的只会对RuntimeException(Unchecked 非受检异常)回滚呢? 

    此时,我们就有必要了解一下,RuntimeException所包含的子类具体有哪些:

             哪些异常是RuntimeException?Sql异常属于RuntimeException吗?Spring下SQL异常事务回滚

这时,或许你就明白了 : 平常代码运行阶段经常遇到的那些异常,其实都是RuntimeException的子类。

            受检异常(Checked)一般在编译期就被检出,这就给你造成了一个Spring对于所有异常都会发生回滚的误解。

             下面给出一些受检CHECKED异常:

           哪些异常是RuntimeException?Sql异常属于RuntimeException吗?Spring下SQL异常事务回滚 哪些异常是RuntimeException?Sql异常属于RuntimeException吗?Spring下SQL异常事务回滚

二,为什么我在执行方法的时候出现了SQL执行的Exception,默认配置的情况下,事务还是发生了回滚 ?                                               下结论之前,我们应该仔细查看异常信息:

[Request processing failed; nested exception is org.springframework.dao.DuplicateKeyException:   
### Error updating database.  Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry '1' for key 1  

          下面我会给出 一个例子:类似于直播软件中,“礼物的购买事务”,其中有三个动作:
              ①Mygift数量的增加            ②Customer余额的减少         ③consumption消费明细的增加

 int a=consumpDao.insert(s);//插入消费明细  
    int b=customerDao.insert(customer);//此处实际应该update(customer),不然会出现重复主键的异常  
    int d=0;  
    if(mygift==null){//判断礼物类型是否存在,第一次插入,而后更新  
        m.setMySum(s.getGiftSum());  
        d=mygiftDao.insert(m);  
    }else{  
        mygift.setMySum(mygift.getMySum()+s.getGiftSum());  
        d=mygiftDao.update(mygift);  
    }  
    if(a*b*d==1){  
        json.put("result",0);  
        json.put("msg", "购买成功");  
        json.put("data", "");  
    }else{  
        json.put("result",-1);  
        json.put("msg", "购买失败");  
        json.put("data", "");  
        TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();  
    }  
}  

                 在程序28行,明确指出:

int a=consumpDao.insert(s);//插入消费明细  
int b=customerDao.insert(customer);//此处实际应该update(customer),不然会出现重复主键的异常  

                 程序运行之前,Consumption消费记录中只有一条数据。
                           
                 程序运行,出现异常,具体如下:

[Request processing failed; nested exception is org.springframework.dao.DuplicateKeyException:   
### Error updating database.  Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry '1' for key 1  

                对应事务中的三个动作,理论发生:      

               ①Consumption消费明细的增加 执行成功,②Customer余额的减少SQL语句在执行的时候发生异常,③Mygift数量增加 执行成功

                程序运行后,Consumption消费记录并没有出现第二条:

               所以此时,该事务发生了回滚。org.springframework.dao.DuplicateKeyException 应该是RuntimeException的子类

三,作出结论,是SQLException属于RuntimeException的子类?还是默认配置一般异常也会回滚呢?                            
                   ① 查看接口文档java.lang.SqlException, 
                        java.lang.Object
                             |____java.lang.Throwable
                                  |____ java.lang.Exception
                                       |____ java.lang.SQLException

                      可以看出: java.lang.SqlException,确实是Exception的直接子类,属于CHECKED受检异常,事务是不会因为它发生回滚的!

                   ② 实际上,当我们在项目开发中加入了Spring框架以后,SQL异常都被org.springframework重写,正如上面的重复主键的SQL异 常。
                       产生原因:很显然该异常原因属于一般异常,而被Spring捕捉后抛出其他自定义的RuntimeException

                       具体可见:org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate()

Error updating database.  Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry '1' for key 1  

                      抛出的异常:

[Request processing failed; nested exception is org.springframework.dao.DuplicateKeyException:

                      我们知道 org.springframework.dao.DuplicateKeyException来自spring-tx-4.0.0.RELEASE.jar
                      反编译可见:
                      java.lang.Object
                               |____java.lang.Throwable
                                    |____ java.lang.Exception
                                         |____ java.lang.RuntimeException
                                              |____ org.springframework.core.NestedRuntimeException
                                                  |____org.springframework.dao.DataAccessException
                                                       |____  org.springframework.dao.NonTransientDataAccessException
                                                           |____org.springframework.dao.DataIntegrityViolationException
                                                               |____org.springframework.dao.DuplicateKeyException
                     同样方法可以查得:org.springframework.dao中的异常都是RuntimeException的子类

 得出结论:Spring框架下,所有SQL异常都被org.springframework重写为RuntimeException,事务因此也会发生回滚!

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161473.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • android采用videoView播放视频(包装)

    android采用videoView播放视频(包装)

    2022年1月12日
    41
  • iOS开发的知名个人博客及几个网站「建议收藏」

    iOS开发的知名个人博客及几个网站「建议收藏」王巍的博客:王巍目前在日本横滨任职于LINE。工作内容主要进行Unity3D开发,8小时之外经常进行iOS/Mac开发。他的陈列柜中已有多款应用,其中番茄工作法工具非常棒。 http://onevcat.com池建强的博客:池建强,70后程序员,Blogger。98年毕业,先后就职于洪恩软件、RocketSofeware和用友软件工程公司(后更名为瑞友科技),现任瑞友科技IT应用研究

    2022年7月11日
    17
  • 李彦宏现身巴黎Viva科技大会:机遇常在,未来通过科技和创新改变生活[通俗易懂]

    李彦宏现身巴黎Viva科技大会:机遇常在,未来通过科技和创新改变生活[通俗易懂]近日,为期三天的“VivaTechnologyParis2016”科技峰会在法国巴黎举办,李彦宏受邀出席。阳狮集团董事长兼CEOMauriceLevy担当峰会对话主持,共议全球…

    2022年10月30日
    0
  • 语音合成学习(一)综述

    语音合成学习(一)综述一、资料推荐爱丁堡大学课程(全英文,有能力的推荐学习一遍):https://speech.zone/courses/speech-synthesis/TensorflowTTS(比较系统的开源项目):https://github.com/TensorSpeech/TensorFlowTTS二、基础概念介绍1、时域:波形的振幅、频率;2、频域:傅里叶变换:每个复杂的波形都可以由不同频率的正弦波组成;语谱(spectrum):描述了信号包含的频率成分和它们的幅度;语谱图(spectrogram

    2022年6月26日
    53
  • 软件封装工具(牛人自制升降工具)

    平时Java项目的开发通常需要统一管理日志(Log)的输出,例如控制日志信息输送的目的地(控制台、文件等),控制每一条日志的输出格式,把日志分为不同的级别等。常用的比较成熟的Java日志管理工具有Apache的Log4j等。但有时我们平时一时兴趣想写个小Dmeo或小工具,想较好的控制日志的输出,引入专业的日志管理库又显得比较繁琐,下面我就自己封装一个简单的日志工具类(LogUtils.java)。

    2022年4月13日
    38
  • linux新增硬盘挂载_磁盘挂载什么意思

    linux新增硬盘挂载_磁盘挂载什么意思1、fdisk-l查看磁盘,并找到要挂载的磁盘(假设为/dev/vdb)2、fdisk/dev/vdb:•m显示命令列表•p显示磁盘分区同fdisk–l•n新增分区•d删除分区•w写入并退出3、顺序:n-输入分区编号-输入分区大小-p(查看分区)-w(保存分区)4、lsblk-l查看分区5、初始化磁盘:mkfs-text4/dev/vdb+分区编号6、lsblk-l查看分区UUID7、mount/dev/vdb+分区编号目

    2022年9月14日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号