MySQL使用了3种锁机制
行级锁,开销大,加锁慢,会出现死锁,发生锁冲突的概率最高,并发度也最高
表级锁,开销小,加锁快,不会出现死锁,发生锁冲突的概率最低,并发度最低
页级锁,开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般
MySQL的存储引擎,这里指常用的,InnoDB,默认是行级锁,如果不指定主键的话,那么就是表级锁了,这点切记
MyISAM是表锁
innoDB
先来了解下MySQL事务
事务是由一组sql语句组成的逻辑处理单元,有4个属性ACID
原子性,Atomicity 事务是一个原子操作单元,数据的改变,要么全部执行,要么全部不执行,有一个不执行,就会全部不执行
一致性,Consistent 事务开始和完成时,数据都是一致的
隔离性,Ioslation 保证事务不受外界干扰,根据隔离性的级别进行独立的运行
持久性,Durable 事务commit之后,对数据的处理是一直有效的,永久性的
MySQL进行事务并发的时候,会带来以下几个问题
脏读,事务A和事务B都操作同一行,A是search,B是update,B更新之后,A进行查询,这个时候,B进行回滚,那么刚刚A查询到的数据就是脏数据,A的操作就是脏读
不可重复读,事务A和事务B都操作同一行,A是search,B是update,A先查询,然后B进行更新,提交,A在查询的时候,和第一次查询的结果不一样,这就是不可重复读
幻读,事务A和事务B都操作同一行,A是update,B是insert,A在更新的过程中,B进行了操作,结果A以为自己没有进行刚刚的操作,就造成了幻读
隔离级别
读数据一致性及允许的并发副作用 隔离级别 | 读数据一致性 | 脏读 | 不可重复读 | 幻读 |
未提交读(Read uncommitted) | 最低级别,只能保证不读取物理上损坏的数据 | 是 | 是 | 是 |
已提交度(Read committed) | 语句级 | 否 | 是 | 是 |
可重复读(Repeatable read) | 事务级 | 否 | 否 | 是 |
可序列化(Serializable) | 最高级别,事务级 | 否 | 否 | 否 |
共享锁,也是读锁,加锁期间,其他事务可以进行读操作,不能进行写操作,直到锁解除
排他锁,也是读写锁,加锁期间,其他事务不能进行读写操作,直到锁解除,