Mysql--13

一、索引语法

  1. 创建索引

sql

复制代码
CREATE [UNIQUE|FULLTEXT] INDEX index_name ON table_name (index_col_name,...);
  • UNIQUE:唯一索引
  • FULLTEXT:全文索引
  • 不加修饰词为普通索引
  1. 查看索引

sql

复制代码
SHOW INDEX FROM table_name;
  1. 删除索引

sql

复制代码
DROP INDEX index_name ON table_name;

二、SQL 执行频率统计

sql

复制代码
SHOW [SESSION|GLOBAL] STATUS LIKE 'Com_______';

可查看:

  • Com_select:查询次数
  • Com_insert:插入次数
  • Com_update:更新次数
  • Com_delete:删除次数

三、慢查询日志

  • 记录执行时间超过 long_query_time(默认 10 秒)的 SQL
  • 开启配置(my.cnf):

ini

复制代码
slow_query_log=1
long_query_time=2
  • 日志默认路径:/var/lib/mysql/localhost-slow.log

四、Profile 性能分析

sql

复制代码
-- 查看所有SQL耗时
show profiles;

-- 查看某条SQL详细耗时
show profile for query query_id;

-- 查看CPU消耗
show profile cpu for query query_id;

五、EXPLAIN 执行计划

sql

复制代码
EXPLAIN SELECT ...;

关键字段含义

  • id:查询序号,id 越大越先执行
  • select_type:查询类型(SIMPLE、PRIMARY、UNION...)
  • type :性能从好到坏NULL > system > const > eq_ref > ref > range > index > ALL
  • possible_key:可能用到的索引
  • key:实际用到的索引
  • key_len:索引使用字节长度
  • rows:预估扫描行数
  • filtered:返回行数占比,越高越好

Extra 关键字段

  • using index condition:用到索引,但需要回表
  • using where; using index:覆盖索引,无需回表

六、索引使用规则

1. 验证索引效率

对比创建索引前后同一条 SQL 的执行耗时。

2. 最左前缀法则

联合索引必须从最左列开始,不能跳过中间列,否则后面索引失效。

3. 范围查询

联合索引中出现 > < 范围查询,范围右侧列索引失效

4. 索引失效场景

  • 字符串不加引号
  • 模糊查询以 % 开头(like '%xxx'
  • OR 连接的条件中有一列无索引
  • 对索引列做函数、运算操作
  • MySQL 判断全表扫描比索引更快时,不使用索引

七、单列索引 & 联合索引

  • 单列索引:单个字段
  • 联合索引:多个字段,优先使用,更容易实现覆盖索引

八、前缀索引

适用于长字符串字段,减少索引空间占用。

sql

复制代码
CREATE INDEX idx_xxx ON table(column(n));

通过计算选择性(不重复值 / 总数)确定前缀长度。


九、覆盖索引

查询的字段全部在索引里,不需要回表查询。尽量避免 select *,只查需要的字段。


十、SQL 提示(手动指定索引)

sql

复制代码
-- 建议使用
USE INDEX(索引名)

-- 忽略索引
IGNORE INDEX(索引名)

-- 强制使用
FORCE INDEX(索引名)

十一、索引设计原则

  1. 数据量大、查询频繁才建索引
  2. 常用于 where /order by /group by 的字段建索引
  3. 选择区分度高的列
  4. 长字符串用前缀索引
  5. 优先建联合索引,少建单列索引
  6. 控制索引数量,避免影响增删改
  7. 索引字段尽量 NOT NULL
相关推荐
无限进步_14 小时前
【C++】从红黑树到 map 和 set:封装设计与迭代器实现
开发语言·数据结构·数据库·c++·windows·github·visual studio
橙子圆12314 小时前
Redis知识2
java·数据库·redis
过期动态14 小时前
【RabbitMQ基础篇】RabbitMQ从入门到实战
java·jvm·数据库·分布式·spring·rabbitmq·intellij-idea
MandalaO_O14 小时前
MySQL:数据库约束
数据库·mysql
qq_4523962315 小时前
第三篇:《JMeter断言:验证接口响应正确性》
android·jmeter
刘~浪地球15 小时前
MongoDB聚合管道进阶:数据处理与统计分析
数据库·mongodb
aqi0015 小时前
一文速览 HarmonyOS 6.0.1 引入的十个新特性
android·华为·harmonyos·鸿蒙·harmony
瀚高PG实验室15 小时前
debezium在LANG=zh_CN.UTF-8下,无法解析timestamp类型的列值为BC的字段
服务器·数据库·postgresql·瀚高数据库
刘~浪地球15 小时前
MongoDB索引优化实战:让查询飞起来
数据库·mongodb