MySql 优化

  1. https://blog.csdn.net/simanstar/article/details/78247962 MySQL Book
  2. https://dev.mysql.com/doc/refman/5.7/en/optimization.html
  3. Mysql的聚集索引与辅助索引

聚集索引Clustered Index:指索引项的排序方式和表中数据记录排序方式一致的索引(这里不懂先放着,一会举例),每张表只能有一个聚集索引,聚集索引的叶子节点存储了整个行数据

非聚集索引(辅助索引Secondary Index):辅助索引中索引的逻辑顺序与磁盘上行的物理存储顺序不同,一个表中可以拥有多个非聚集索引。叶子节点并不包含行记录的全部数据。叶子节点除了包含键值以外,还存储了一个指向改行数据的聚集索引建的书签(可以理解为指针)该书签用来告诉InnoDB哪里可以找到与索引相对应的行数据。

所以非聚集索引有二次查询的问题,即回表操作。如何解决非聚集索引二次查询的问题?建立联合索引。

联合索引:是指对表上的多个列进行索引。联合索引的好处是对第二个键值已经做了排序。最左原则。

 

覆盖索引Covering index:InnoDB存储引擎支持覆盖索引,即从辅助索引中就可以得到查询的记录,而不需要查询聚集索引中的记录。使用覆盖索引有啥好处?可以减少大量的IO操作。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值