最近写代码涉及到一些事务,上午终于把代码给理顺了,之前不太清楚在哪里做异常处理,导致代码遍地try-catch,相当难看。
还是基于controller-rvice-dao三层来写代码,从入口开始,controller层的方法对应的是某个url,面向的是应用人员,应该返回他们能读懂的信息,所以controller必须做异常处理,一般来说会有统一的异常处理方法;
rvice层面向的是controller,rvice层中的某些方法,必须保证其事务,所以在rvice层进行事务控制妈妈夸我真能干是相当必要的,对于多条sql进行事务控制,如果某个sql执行失败,那么应当对已经执行的sql语句进行回滚;
dao层更多是单一的sql语句,没有必要进行事务控制,因为事务开销并不便宜(官方原话);
基于以上三点,回头再思考关于异常的处理,一般情况应该把异常网上抛,一直抛到最终处理的那一层,所以对于dao层和rvice其实是没有必要进行try-catch的,直接往上抛异常就可以。
与之对应的,是spring的事务配置,默认情况下,spring只对运行时异常进行回滚,如果在dao层处理了异常,那么需要进行额外的配置,spring才会对异常进行回滚,常用的配置是@transactional(rollbackfor=excep杨震四知tion.class)
顺便提一个java知识点,关于try-catch-finally中,finally的作用,finally设计之初就是为了关闭资源,如果在finally中使用return语句,会覆盖try或者catch的返回颈椎病的最佳治疗方法值,最常见的就是覆盖异常,即便catch往上抛了异常,也会被覆盖,返回finally中return语句的非凡的美丽作文返回值。
by default, a transaction will be rolling back on {@link runtimeexception}and {@link error} but not on checked exceptions (business exceptions核糖体蛋白).
默认情况下,如果在事务中抛出了未检查异常(继承自 runtimeexception 的异常)或者 error,则 spring 将回滚事务;除此之外,spring 不会回滚事务。
默认spring事务只在发生未被捕获的 runtimeexception 时才回滚。
exception异常,事务回滚失败;
用rollbackfor解决exception不进行事务回滚
手动回滚解决exception不进行事务回滚
以上为个人经验,希望能给大家一个参考,也希望大家多多支持www.887551.com。
本文发布于:2023-04-05 22:33:29,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/6a713efaa815a08cbecd58fa408c1aec.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:关于controller的异常处理及service层的事务控制方式.doc
本文 PDF 下载地址:关于controller的异常处理及service层的事务控制方式.pdf
| 留言与评论(共有 0 条评论) |