java事务四中隔离级别_事务的四种隔离级别

本文详细介绍了数据库的四大特性:原子性、一致性、隔离性和持久性,并重点讲解了事务的四种隔离级别——读未提交、读已提交、可重复读和串行化,以及它们如何解决脏读、不可重复读和幻读问题。MySQL的默认隔离级别为可重复读。
摘要由CSDN通过智能技术生成

数据库四大特性:

原子性:要么全部执行,要么全部回滚。

一致性。“确保一致性是用户的责任,而不是DBMS。”,“DBMS假定每个事务都保持一致性”。数据库和数据管理员通过其他三个特性来保证一致性。即是:从一正确的状态转换到另一个正确的状态

隔离性:一个事务在另外一个事务完成后或者完成前完成。

持久性:物理化信息。

1,读未提交,Read Uncommited。

指的是一个事务读取到另外一个事务还没有提交的内容。这种情况是必须要避免的。因为其他事务未提交的数据,是随时有可能进行回滚的,所以,任何时候,都不应该允许程序读取到某个事务还未提交的数据。如果读取到了别的事务未提交的数据,这种情况称为脏读。要想解决脏读的问题,可以提高数据库的事务隔离级别,把事务隔离级别设置为读已提交。

2,读已提交,Read Committed。

这个隔离级别可以解决脏读的问题。

在该隔离级别下,允许在一个事务执行的过程中,另外一个事务得到执行并提交。这样,会出现一种情况,第一个事务前后两次select出来的某行数据,值可能不一样。值改变的原因是,穿插执行的事务2对该行数据进行了update操作。在同一个事务中,两次select出来的值不相同的问题称为不可重复读问题。要想解决不可重复读问题,需要把数据的隔离级别设置为可重复读。

3,可重复读。Repeatable Read。

在这个隔离级别下,可以解决不可重复读的问题。

在该隔离级别下,在一个事务使用某行的数据的过程中,不允许别的事务再对

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值