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. 查询优化。
相关推荐
极限实验室9 小时前
INFINI Labs 产品更新 - Easysearch 2.1.0 新增高性能 Rules 规则引擎插件,数据探索 Discover 等
数据库·产品
鹿角片ljp11 小时前
苍穹外卖 day05:店铺营业状态设置与Redis入门实战
数据库·redis·缓存
m0_7434703711 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
Demon_Hao11 小时前
JAVA通过Redis实现Key分区分片聚合点赞、收藏等计数同步数据库,并且通过布隆过滤器防重复点赞
java·数据库·redis
掘根12 小时前
【微服务即时通讯】消息转发子服务
数据库·oracle
喜欢喝果茶.12 小时前
SQL 预处理
数据库·sql
数据科学小丫13 小时前
Python 数据存储操作_数据存储、补充知识点:Python 与 MySQL交互
数据库·python·mysql
Knight_AL13 小时前
Nacos 启动问题 Failed to create database ’D:\nacos\nacos\data\derby-data’
开发语言·数据库·python
xianjian091215 小时前
MySQL 的 INSERT(插入数据)详解
android·数据库·mysql
知识分享小能手15 小时前
MongoDB入门学习教程,从入门到精通,MongoDB入门指南 —— 知识点详解(2)
数据库·学习·mongodb