加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

数据库两大必备神器:索引和锁底层原理是什么!

发布时间:2018-11-09 13:36:54 所属栏目:MySql教程 来源:Java3y
导读:【51CTO技术沙龙】10月27日,让我们共同探索AI场景化应用实现之道 一、索引 在之前,我对索引有以下的认知: 索引可以加快数据库的检索速度; 表经常进行INSERT/UPDATE/DELETE操作就不要建立索引了,换言之:索引会降低插入、删除、修改等维护任务的速度;

表锁其实我们程序员是很少关心它的:

  •  在MyISAM存储引擎中,当执行SQL语句的时候是自动加的。
  •  在InnoDB存储引擎中,如果没有使用索引,表锁也是自动加的。

现在我们大多数使用MySQL都是使用InnoDB,InnoDB支持行锁:

  •  共享锁--读锁--S锁
  •  排它锁--写锁--X锁

在默认的情况下,select是不加任何行锁的~事务可以通过以下语句显示给记录集加共享锁或排他锁。

  •  共享锁(S):SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE。
  •  排他锁(X):SELECT * FROM table_name WHERE ... FOR UPDATE。

InnoDB基于行锁还实现了MVCC多版本并发控制,MVCC在隔离级别下的Read committed和Repeatable read下工作。MVCC能够实现读写不阻塞!

InnoDB实现的Repeatable read隔离级别配合GAP间隙锁已经避免了幻读!

  •  乐观锁其实是一种思想,正如其名:认为不会锁定的情况下去更新数据,如果发现不对劲,才不更新(回滚)。在数据库中往往添加一个version字段来实现。
  •  悲观锁用的就是数据库的行锁,认为数据库会发生并发冲突,直接上来就把数据锁住,其他事务不能修改,直至提交了当前事务

三、总结

本文主要介绍了数据库中的两个比较重要的知识点:索引和锁。他俩可以说息息相关的,锁会涉及到很多关于索引的知识~

【编辑推荐】

  1. 高性能数据库连接池的内幕
  2. OSDI '18重磅解密:蚂蚁金服实时金融级分布式图数据库GeaBase
  3. 关于MySQL通用查询日志和慢查询日志分析
  4. 这样做数据清理,可以避免引发MySQL故障
  5. 分布式数据库TiDB在商业银行的设计与实践
【责任编辑:庞桂玉 TEL:(010)68476606】
点赞 0

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!