- MySQL的锁机制是为了数据库数据的完整性;
- MySQL锁分为行锁和表锁,行锁:对于一条数据,只有等我操作完了,你才能对这条数据进行操作;针对某条数据的,innobd存储引擎支持行锁。表锁:对于一张表,我正在操作数据,那么这张表的所有数据都必须等我操作完了你才能操作,针对的是整张表,myisam存储引擎支持表锁;
- myisam的表锁又分为两种,表读共享锁和表写独占锁。即读的时候大家都可以读,但是不能写;写的时候,既不能读也不能写;读写,写写之间都是串行的;
- myisam存储引擎的数据库在select操作的时候会自动给表加上读锁,在执行update insert delete的时候会走动的给数据表加上写锁,不需要认为干预;
- myisam可以通过设置达到并发插入,myisam存储引擎中有一个系统变量concurrent_isnert,其值为0,1,2。0不允许并发插入;1允许在读的同时在表尾插入记录;2允许并发插入;
- innodb存储引擎支持事务;
- innodb的行锁也分为两种,共享锁和排他锁。意思分别是:对于这一行可以一起读;对于这一行不管是我读还是写只能由我来进行
- 关于死锁:myisam表不会出现死锁,因为myisam总是一次性获得全部锁,要么满足执行,要么就是等待。而innodb中,锁是逐步获得的,有可能出现死锁。死锁顾名思义就是两个事务同时获得锁然后互不让步;而innodb一般都能自动检测到死锁,并使一个事物释放锁并回退,另一个事务获得锁继续执行;
- 死锁也有检测不到的情况我们通过以下来解决
- 多个业务操作一张表,业务排序
- sql批量执行的时候数据排序
- 在事务中如果要更新数据,应该申请排他锁
- 设置更高的隔离级别可以避免死锁
- innodb间隙锁:select * from user where id > 100.那么对于id大于100的记录会加上锁,不管这些记录存在不存在(比如id只到101),这个锁称为间隙锁;因为在查询的过程中如果另一个事务插入一条数据,那么id应该是102,这样防止我们查询的时候产生幻读;