mysql核心知识整理

目录

  1. 聚簇索引与非聚簇索引;
    聚簇索引:找到了索引就找到了需要的数据,那么这个索引就是聚簇索引,所以主键就是聚簇索引,修改聚簇索引其实就是修改主键。
    非聚簇索引:索引的存储和数据的存储是分离的,也就是说找到了索引但没找到数据,需要根据索引上的值(主键)再次回表查询,非聚簇索引也叫做辅助索引。
  2. 覆盖索引;
    覆盖索引:联合索引中,查询的字段可以全部在辅助索引中找到,不需要回表时,就叫覆盖索引。
    例如:unikey(a,b,c),select a,b,c from table where a like "hello%" 这种就直接走辅助索引树遍历。select a,b,c,d from table where a like "hello%"这种就会出现回表查询d字段的情况,就不叫覆盖索引。
  3. 索引下推;
    索引下推:联合索引中,击中了辅助索引的前面字段,后面的字段会在存储引擎层就过滤出来。
    例如:select * from people where country like '中%' and name = '张三' 联合索引unikey(country,name),这个sql会用到辅助索引unikey的country字段,在5.6以前没有索引下推,存储引擎会将country like '中%'的数据全部返回给server层由server层来过滤剩下的条件name = '张三',把不符合条件的过滤掉返回给client端,但是在5.6以后有了索引下推icp,这时候会直接在server层就对name = '张三'的数据进行过滤,返回给server端,这就是索引下推。相当于把server层的判断交给存储引擎层。
  4. 最左原则;
    最左原则:联合索引中,查询的条件按左到右的顺序击中。
    例如:unikey(a,b,c),select * from table where a = "hello" and b like "a%" 这种就是满足了最左原则,mysql执行器会选用辅助索引。select * from talbe where b = "word" 这种就没有满足最左原则,mysql会直接执行全表扫描。
  5. 索引结构 b树、b+树、跳表(redis);
    b树:数据存在每个节点上;mongdb
    b+树:数据只是存在叶子节点上;mysql
    跳表:单向有序链表+多级索引。redis
  6. 回表;
    回表:是指查询的条件击中了辅助索引,但是查询的字段除了辅助索引的字段外,还需要到主键索引树中查找的情况就叫做回表。
  7. binlog、redolog、undolog;
  8. mvcc;
  9. 锁;
  10. 查询优化。
相关推荐
IT项目管理20 分钟前
达梦数据库DMHS介绍及安装部署
linux·数据库
你都会上树?28 分钟前
MySQL MVCC 详解
数据库·mysql
大春儿的试验田33 分钟前
高并发收藏功能设计:Redis异步同步与定时补偿机制详解
java·数据库·redis·学习·缓存
Ein hübscher Kerl.1 小时前
虚拟机上安装 MariaDB 及依赖包
数据库·mariadb
长征coder1 小时前
AWS MySQL 读写分离配置指南
mysql·云计算·aws
醇醛酸醚酮酯2 小时前
Qt项目锻炼——TODO清单(二)
开发语言·数据库·qt
ladymorgana2 小时前
【docker】修改 MySQL 密码后 Navicat 仍能用原密码连接
mysql·adb·docker
PanZonghui2 小时前
Centos项目部署之安装数据库MySQL8
linux·后端·mysql
GreatSQL社区2 小时前
用systemd管理GreatSQL服务详解
数据库·mysql·greatsql
掘根2 小时前
【MySQL进阶】错误日志,二进制日志,mysql系统库
数据库·mysql