Spring的事务控制——学习历程

思考:

  1. 事务是干什么的?

  2. 事务的特性?

  3. 事务控制的传播方式(传播行为)

  4. 事务的隔离级别

  5. 事务是如何实现的?

  6. 事务的回滚方式

  7. 事务失效场景

回答:

  1. 事务和锁,还有版本控制 都是为了保证数据一致性的。

  2. 事务都是围绕着ACID来的(分布式事务CAP),A是原子性 ,把整个事务看做为一个不可分的原子,必须都对,或者都错;C是一致性 ,事务执行前,数据库处于一致状态;执行后,即使发生故障,数据库仍须保持一致性(例如:转账前后总金额不变);I是隔离性 ,事务和事务之间相互隔离,互不干扰;D是持久性,他主要是针对数据库层面,一旦事务完成,他的CRUD就都保存在数据库里,被持久化了。

  3. Spring 支持多种事务传播行为,例如:

  • PROPAGATION_REQUIRED:如果当前存在事务,则加入该事务;否则新建一个事务。
  • PROPAGATION_REQUIRES_NEW:无论当前是否存在事务,都新建事务,并挂起当前事务。
  • PROPAGATION_SUPPORTS:支持当前事务,不存在则以非事务方式执行。
  • PROPAGATION_MANDATORY:必须存在事务,否则抛出异常。
  • PROPAGATION_NEVER:不能存在事务,否则抛出异常。
  • PROPAGATION_NESTED:在嵌套事务中执行。
  1. 事务的隔离级别相比MySQL数据库多了一个级别:默认(DEFAULT
  • DEFAULT:使用数据库默认的隔离级别。

MySQL的隔离级别有:可序列化 > 可重复度(幻读) > 读已提交(脏读) > 读未提交

  1. 是采用的AOP方法,@Transaction为标识,每次开启动态代理(Java的动态代理,JDK),在同一个线程内,多个 DAO 操作可以共享同一个数据库连接和事务。当事务提交或回滚后,这些资源会被释放。

6.回滚方式:(我记得好像可以调节隔离级别查看事务的回滚过程【之前尝试过,现在有点不清晰了】)

  • 默认情况下,Spring 只对运行时异常(RuntimeException 及其子类)和 Error 进行回滚。
  • 可以通过 rollbackFor 和 noRollbackFor 属性自定义哪些异常触发回滚。

7.(鞭策AI给的一份应面回答)

补充:

  1. JDK代理 和 CGLIB代理的区别 :前者靠反射, 后者考继承,前者主要针对接口类,后者针对非接口,非final的类
相关推荐
SHoM SSER几秒前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
蒸蒸yyyyzwd30 分钟前
后端学习笔记 day4
linux·笔记·学习
熬夜的咕噜猫32 分钟前
MySQL备份与恢复
数据库·oracle
jnrjian1 小时前
recover database using backup controlfile until cancel 假recover,真一致
数据库·oracle
MX_93591 小时前
SpringMVC请求参数
java·后端·spring·servlet·apache
lifewange1 小时前
java连接Mysql数据库
java·数据库·mysql
大妮哟2 小时前
postgresql数据库日志量异常原因排查
数据库·postgresql·oracle
还是做不到嘛\.2 小时前
Dvwa靶场-SQL Injection (Blind)-基于sqlmap
数据库·sql·web安全
笨笨饿2 小时前
20_Git 仓库使用手册 - 初学者指南
c语言·开发语言·嵌入式硬件·mcu·学习
不写八个3 小时前
PHP教程004:php链接mysql数据库
数据库·mysql·php