– 事务的传播机制
– 事务之间相互影响,泛指两个或者两个以上事务之间的相互影响
– 事务的传播机制分类:
– 支持当前事务
– 不支持当前事务
– 嵌套事务
– 支持当前事务
– propagation_required:required(依赖)如果当前存在事务,则使用当前事务,如果当前不存在事务,则创建新的事务
– propagation_support:support(支持)如果当前存在事务,则使用当前的事务,如果当前不存在事务,则创建新的事务,并以非事务的方式运行
– 什么是事务?
– 事务是我们一系列sql语句的集合,事务具有原子性,要么全部执行成功,要么全部执行失败
– 事务的运行方式:事务中的sql语句,要么全部执行成功,要么全部执行失败
– 非事务的运行方式:事务中的sql语句彼此不联系,其中的一条sql语句,执行成功了,就是执行成功了,执行失败了就是执行失败了
– CRUD
– 查询 select * from user
– 删除 delete from user where id=1
– 修改 update user set name=“小刘” where id=1
– 插入 insert into user values(1,1001,“刘某”,“男”)
– propagation_madenatory:如果当前存在事务,则使用当前事务,如果当前不存在事务,则抛出异常,并以非事务的方式运行
– 不支持当前事务
– propagation_required_new:如果当前存在事务,则挂起当前事务,如果当前不存在事务,则新建事务
– 挂起:中断/暂停服务
– propagation_not_support:如果当前存在事务,则挂起当前事务,如果当前不存在事务,则新建事务,并以非事务的方式运行
– propagation_never:如果当前存在事务,则挂起当前事务,如果当前不存在事务则,抛出异常,并以非事务的方式运行
– 嵌套事务
– propagation_nested:nested(嵌套):如果当前存在事务,则在嵌套事务里运行,如果当前不存在事务,则新建事务
– @Transactional事务注解,既可以作用于类上,也可以作用于方法上
– @Transactional(isolation=isolation.DEFAULT,propagation=propagation.support,timeout=1,readOnly=true,rollbackfor=NullPointerException.class,norollbakcfor=ClassCastException.class)
– isolatioal:隔离级别
– propagation:事务的传播机制
– timeout:超时时间
– readOnly:只读 true 更新 false
– rollbackfor:回滚
– norollbackfor:不回滚