标签:隔离 不能 ber 翻译 读取数据 str 访问 事务隔离 事务
不可重复读,unrepeatable read,翻译出来的无法体会原词含义。翻译成无法重复读会更好一些,或者直接用英文更能体会原意。
unrepeatable read是相对repeatable read,即可重复读。这个需求是,保证可以重复读取一条数据,详细的说法是,保证在一个事务中,重复读取一条数据,这条数据不变(即这条数据不会被其他事务改变)。
一个完整的transaction中不受到其他的transaction影响。
例如转账,A转账给B,在这个transaction发生的同时,A的电费自动扣款也发生了。
假设,在A转账这个transaction中,有3次访问数据库:
第1次,查询,获取金额。
第2次,更改金额。
第3次,再查询,获取余额。
我们定义,这三次是一个完整的事件。那么在这个事件中就不能受到电费自动扣款的影响(主要是第3次查询数据库)。
这就是repeatable read(可重复读,在一个完整的transaction中)。
脏读:读到了某个事务还未提交的数据。
不可重复读:一个事务读到了另一个事务已经提交的更改的数据
幻读/虚读:一个事务读到了另一个事务已经提交的新增的数据
1读未提交:一个事务在执行过程中,可以读取其他事务未提交的数据。如果一个事务已经开始写数据,则另外一个事务不允许同时进行写操作,但允许其他事务读此行数据。
2读已提交:一个事务在执行过程中,可以读取其他事务已经提交的数据,可以有效防止脏读。
4可重复读:一个事务在执行过程中,可以访问其他事务成功提交的新插入的数据,但是不可以访问其他事务成功修改的事务。读取数据的事务将会禁止写事务但是允许读事务,写事务则禁止任何其他事务。此隔离级别可有效的防止不可重复读和脏读。
8序列化/串行化:提供严格的事务隔离,它要求事务序列化执行,不能并发执行。可以有效的防止脏读、不可重复读和幻读。
标签:隔离 不能 ber 翻译 读取数据 str 访问 事务隔离 事务
原文地址:https://www.cnblogs.com/globalcoding/p/12827040.html