首页常见问题正文

Java数据库操作常识:事务的四大特性

更新时间:2022-09-29 来源:黑马程序员 浏览量:

IT培训班

  事务有很严格的定义,它必须同时满足4个特性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability),也就是人们俗称的ACID标准,接下来就针对这4个特性进行讲解,具体如下。

  1.原子性

  原子性是指一个事务必须被视为一个不可分割的最小工作单元,只有事务中所有的数据库操作都执行成功,才算整个事务执行成功,事务中如果有任何一个SQL语句执行失败,已经执行成功的SQL语句也必须撤销,数据库的状态退回到执行事务前的状态。

  2.一致性

  一致性是指事务将数据库从一种状态转变为下一种一致的状态。例如,在表中有一个字段为姓名,具有唯一约束,即姓名不能重复,如果一个事务对姓名进行了修改,使姓名变得不唯一了,这就破坏了事务的一致性要求,如果事务中的某个动作失败了,系统可以自动撤销事务,返回初始化的状态。

1664418129557_事务的4大特性.jpg

  3.隔离性

  隔离性还可以称为并发控制、可串行化、锁等,当多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。

  4.持久性

  事务一旦提交,其所做的修改就会永久保存到数据库中,即使数据库发生故障也不应该对其有任何影响。需要注意的是,事务的持久性不能做到100%的持久,只能从事务本身的角度来保证永久性,而一些外部原因导致数据库发生故障,如硬盘损坏,那么所有提交的数据可能都会丢失。

  需要注意的是,针对事务的4个特性有个简单的印象就可以了,不必太过斟酌,事务的操作才是重点掌握的内容。

分享到:
在线咨询 我要报名
和我们在线交谈!