未提交读
@Transactional(isolation = Isolation.READ_UNCOMMITTED)
//未提交读:第一个事务还没提交,在第二个接口插入另外一条数据时,可以看到之前还没提交那个事务插入的数据,因此有脏数据
读写提交
@Transactional(isolation = Isolation.READ_COMMITTED)
//读写提交:第一个事务还没提交,在第二个接口插入另外一条数据时,不能看到之前没有提交那个事务,在执行第二个事务时,只能看到当前插入的数据,就算事务1已经执行完成了,在事务二执行中还是看不见事务一提交的(不可重复读:在事务二执行执行过程中查到的数据(无事务一刚插入的数据),跟事务二执行完之后重新查的数据(有事务1的数据)不一样)
可重复读
@Transactional(isolation = Isolation.REPEATABLE_READ)
//可重复读:第一个事务还没提交,在第二个接口插入另外一条数据时,不能看到之前没有提交那个事务,但当事务一在事务二执行过程总完成了,在执行第二个事务时,是能看见刚刚事务一执行完的结果的,因此会解决上述的不可重复读问题。那为什么会有幻读?这个是在事务二在执行中,在事务一没提交之前,查不到事务一的数据,但是事务1比事务2执行的快,事务1已经提交了,在事务二执行过程中能读取到事务一提交的数据,所以幻读是针对于在事务二执行过程中前后两次读取数据不一样
串行化
@Transactional(isolation = Isolation.SERIALIZABLE)
//串行化:事务二要等到之前事务一那个提交了之后,才可以执行事务二的操作,所以是串行的,没有脏数据、不可重复度、幻读。因为事务二要等事务一执行完才能执行。