mysql的锁机制

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dong__xue

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值