MySql的事务隔离级别
一,未提交读
顾名思义,未提交读就是能够读取到事务尚未提交所产生的数据。这种隔离方式会产生一种问题就是“脏读”。
脏读:
比方说有两个事务A B 在A事务里面将数据的id更改为2,但是A事务尚未提交。此时B事务进行查询,查询到的结果id=2。但是此时A事务回滚了,那么B事务再次读取的时候就会发现,刚刚Id还等于2,现在怎么又等于1了??
二,提交读
顾名思义,提交读就是只能读取到事务已经提交后产生的结果。这种隔离方式会产生一种问题就是在同一个事务下可能会读取到不同的数据。
比方说:现在有A B两个事务,A事务一开始查询数据结果是Id=1,但是此时B事务更改了数据,然后迅速的提交了(在A提交前提交),这是在A中再次查询数据发现ID又变成2了,这是就会出现杠杆Id现在还等于1,现在怎么又等于2了???
三,可重复读
可重复读指的是:“在事务内任意时刻读取到的数据都与事务刚开启时的数据一致”,比方说我在12点01分开启了A事务,然后我在12点01分查询数据结果是ID等于2,然后12点02分其他线程更改了数据将ID更改了为8。此时A事务尚未提交,A事务此时再次查询发现Id还是2,也就是说只要事务未提交在事务开启的时间内的任意时刻读取的数据都与事务刚刚开启时一致。这就会导致一个问题。
比方说有两个事务A B 在A里面先查询发现表里面没有数据,此时另一个事务往表里面插入了一条数据然后迅速提交,此时A里面查询的数据还是空的,然后再往里面插入一个相同ID的数据,这时就爆主键冲突的异常了。明明没有数据为什么还会有异常呢???
4,串行化,这个未做深入了解!