数据库的常见问题、隔离机制、锁机制

一、数据库常见问题

平时开发过程中,避免不了对数据库的操作,尤其是多线程,因此数据库中高并发场景十分常见。由此会引发一些交叉访问数据不一致的问题如下:

1、脏读 
脏读就是一个事务读取了另外一个事务未提交的数据。 
 è¿éåå¾çæè¿°
事务2读取了事务1未提交的数据。

2、不可重复读 
在同一事务中,两次读取同一数据,得到内容不同。 
例如事务1读取了某个数据,然后事务2更新了这个数据并提交,然后事务1又来读取了一次,那这两次读取的结果就会不一样。 

è¿éåå¾çæè¿°

3、幻读 
在一个事务的两次查询中数据记录数不一致,例如有一个事务1查询了几列数据,而事务2在此时插入了新的几列数据,事务1在接下来的查询中,就会发现有几列数据是它先前所没有的。 

è¿éåå¾çæè¿°

不可重复读是针对于多次读取同一条数据出现不同结果,幻读是多次读取而产生的记录数不一样

二、事务及其隔离级别

1、为了解决上述问题我们给数据库引入了事务,那么什么是事务?

简单的说,事务就是并发控制的单位,是用户定义的一个操作序列。
而一个逻辑工作单元要成为事务,就必须满足ACID属性。
A:原子性(Atomicity)
    事务中的操作要么都不做,要么就全做。
C:一致性(Consistency)
    事务执行的结果必须是从数据库从一个一致性状态转换到另一个一致性状态。
I:隔离性(Isolation)
    一个事务的执行不能被其他事务干扰
D:持久性(Durability)
    一个事务一旦提交,它对数据库中数据的改变就应该是永久性的

2、为解决上述问题可以给数据库设置响应的隔离界别,有以下5中隔离级别:

TRANSACTION_NONE :无事务
TRANSACTION_READ_UNCOMMITTED :允许脏读,不可重读,幻读。
TRANSACTION_READ_COMMITTED:仅允许读取已提交的数据,即不能脏读,但是可能发生不可重读和幻读。
TRANSACTION_REPEATABLE_READ :不可读脏,可重复读(即多次读取数据一致),但是可能发生幻读。
TRANSACTION_SERIALIZABLE :串行事务,保证不读脏,可重复读,不可幻读,事务隔离级别最高。

注:各个隔离级别的设置与测试,详见参考博文的第一篇博文,作者给出了详细的阐述。


三、锁机制

1、锁分类

①、按操作划分:DML(CRUD操作数据库数据的操作)锁,DDL(create/alter/drop等操作数据库结构的操作)锁
②、按锁的粒度划分:表级锁、行级锁、页级锁
③、按锁级别划分:共享锁、排他锁
④、按加锁方式划分:自动锁、显示锁
⑤、按使用方式划分:乐观锁、悲观锁

2、行级锁、表级锁和页级锁

行级锁:行级锁分为共享锁和排它锁。行级锁是Mysql中锁定粒度最细的锁。InnoDB引擎支持行级锁和表级锁,只有在通过索引条件检索数据的时候,才使用行级锁,否就使用表级锁。行级锁开销大,加锁慢,锁定粒度最小,发生锁冲突概率最低,并发度最高

表级锁:表级锁分为表共享锁和表独占锁。表级锁开销小,加锁快,锁定粒度大、发生锁冲突最高,并发度最低

页级锁:页级锁是MySQL中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录。BDB支持页级锁。
开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般

3、排它锁与共享锁

排它锁(exclusive locck)
排它锁又叫写锁,如果事务T对A加上排它锁,则其它事务都不能对A加任何类型的锁。获准排它锁的事务既能读数据,又能写数据。用法:SELECT ... FOR UPDATE  

共享锁(share lock)
共享锁又叫读锁,如果事务T对A加上共享锁,则其它事务只能对A再加共享锁,不能加其它锁。获准共享锁的事务只能读数据,不能写数据。用法:SELECT ... LOCK IN SHARE MODE;

4、乐观并发控制和悲观并发控制是并发控制采用的主要方法。悲观锁是指在数据处理过程,使数据处于锁定状态,一般使用数据库的锁机制实现。悲观并发控制(悲观锁)采用"先取锁再分"的保守策略,为数据处理提供了安全的保证。但在效率方面,加锁机制会产生额外的开销,增加产生死锁的机会。乐观锁:相对悲观锁来说,乐观锁是通过记录数据版本的方式实现乐观锁。为数据增加一个版本标识,读取数据时,将版本标识一起读出,数据没更新一次,就对版本标识进行更新。乐观锁认为事务直接竞争的概率是很小的,在提交的时候才锁定,所以不会产生死锁。但是如果两个事务同时读取数据库的某一行,这时,就会发现乐观锁的弊端。

 

参考博文:

https://blog.csdn.net/qq_34975710/article/details/81077178

https://www.jianshu.com/p/817fdd7ba8ea

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值