数据库(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

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值