【学习笔记】Spring事务五大隔离级别

事务是什么?

事务(Transaction),一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。

例如:在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。

事务应该具有4个属性: 原子性、一致性、隔离性、持久性 。这四个属性通常称为ACID特性。

事务特性含义
原子性(atomicity)一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。
一致性(consistency)事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
隔离性(isolation)一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰
持久性(durability)持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响
不考虑隔离性引发安全性问题

**脏读 :**在一个事务中读取到另一个事务没有提交的数据

**不可重复读:**在一个事务中,两次查询的结果不一致(针对的update操作)

**虚读(幻读):**在一个事务中,两次查询的结果不一致(针对的insert操作)

解决以上的问题,要该怎么办呢?答案是利用spring事务隔离API

隔离级别含义读脏数据不可重复读幻读
DEFAULT使用数据库默认的事务隔离级别---
READ_UNCOMMITTED一个事务可以读取到另一个事务未提交的事务记录。未解决未解决未解决
READ_COMMITTED一个事务只能读取到已经提交的记录,不能读取到未提交的记录。解决未解决未解决
REPEATABLE_READ一个事务可以多次从数据库读取某条记录,而且多次读取的那条记录都是一致的,相同的解决解决未解决
SERIALIZABLE事务执行时,会在所有级别上加锁,事务是以串行的方式进行的,而不是一起发生的。但是,会带来性能的下降。解决解决解决
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值