事物隔离级别

1.定义

数据库事物操作必须满足原子性,一致性,隔离性,持久性
- 原子性:程序中所有操作,要么全部完成,要么全部不完成,不会停滞在某个环节
- 一致性:操作执行前后数据需要保持一致
- 持久性:update、insert操作执行后必须瞒住能够持久化在数据库中
- 隔离性:是指不同的客户端在做事务操作时,理想状态下,各个客户端之间不会有任何相互影响(真正隔离的对象在实现上是数据库资源的互斥性访问,隔离性就是通过数据库资源划分的不同粒度体现的)

数据库性能的一个衡量标准:
TPS: 单位时间内的事务数(Transactions Per Second),TPS越高,表示数据库的性能越好。
最大TPS = 1 / T (T 为客户端的平均事务操作时间)
例如:T = 10ms, 那么数据库此时的TPS值 为 1 / 0.01 = 100, 即数据库每秒能够完成100个事务操作

1.1隔离级别

1.1.1库级

对数据库上锁,同时只能一个操作访问数据库,其它客户端等待其执行完,才能操作该数据库,
问题:导致执行效率慢,占用内存资源多

1.1.2表级锁——序列化读(SERIALIZABLE READ)

对数据库中的表上锁,不同的客户端对同一数据库同时只能进行两张不同的表操作。
(实际中,一个客户端的事物可能同时对不同的表进行操作)。目前主流数据库多是通过此方式实现资源互斥,
通过*锁全表*的方式进行的事务隔离处理,在操作时序上,是排队性质进行的,这种事务*隔离的级别最高*,
即:序列化读(SERIALIZABLE READ)。

1.1.3 行级锁

1.1.3.1 可重复读(REPEATABLE_READ)

问题:在同一个事务内,完全相同的两次查询,返回的记录数不一致,好像多读了数据一样,这种情况,称为***幻读(Phantom Read)***
解决:避免幻读的方式,可以使用表级锁—即提高事务的隔离界别—序列化读(SERIALIZABLE READ)

1.1.3.2 读已提交(READ_COMMITTED)

问题:前后对同一ID(同行)的两次查询,查询结果不同,这种现象叫做读已提交的的不可重复读
解决:要求我们在数据库事务操作上,尽可能少用查询出来的结果作为参数执行后续的updateSQL 语句,尽可能使用状态机来保证数据的完整性

1.1.3.3 读未提交(READ_UNCOMMITTED)

问题:对同一ID(同行)的查询,查询结果不同,因为其他客户端事物执行更新操作后还未持久化到数据库,之后本客户端误以为它是持久化到数据库上的,所以查询结果是从缓存中查询出来的,导致前后查询结果不一致,称为***脏读***。

注:拜读大佬文章总结,原文会有更清晰解释
原文链接:https://blog.csdn.net/luanlouis/article/details/95319795#comments
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值