数据库(3)事务

越努力越幸运!

事务指的是逻辑上的一组操作,这组操作要么全部成功,要么全部失败。

一般的事务指的都是数据库事务,但是广义事务的定义不局限于数据库事务。

事务有4大特性,即 ACID。

ACID,指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。一个支持事务(Transaction)的数据库,必需要具有这四种特性,否则在事务过程(Transaction processing)当中无法保证数据的正确性,交易过程极可能达不到交易方的要求。

1、原子性

事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

2、一致性

事务前后数据的完整性必须保证一致

比如还是刚刚A给B转账的例子,那么A给B转账结束后,总金额不变。

3、隔离性

多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要互相隔离。

隔离性非常重要,如果不考虑隔离性,就可能发生:脏读、不可重复读、幻读的问题

(1)脏读

一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据无效。

这里写图片描述

(2)不可重复读

在同一事务中,多次读取同一数据返回的结果不同。

这里写图片描述

(3)幻读

一个事务读取了几行记录后,另一个事务插入一些记录。后来的查询中,第一个事务就会发现有些原来没有的记录。

这里写图片描述

当然,这些问题是有办法避免的,有隔离级别来限制,后面做解释。

4、持久性

一个事务一旦提交,它对数据库中的数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响

事务的隔离级别(4种)

事务的隔离级别是为了防止脏读、不可重复读、幻读问题的发生,具体分成四种,如下:

这里写图片描述

Spring有一个default隔离级别,底层数据库用的哪个隔离级别,spring就用什么隔离级别
MySQL用的是repeatable_read
Oracle用的是read_committed

有一个更加直观的表格如下:

这里写图片描述

--------------------- 本文来自 This is bill 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/Scythe666/article/details/51841161?utm_source=copy

猜你喜欢

转载自blog.csdn.net/hezuo1181/article/details/82948662