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
相关推荐
Meepo_haha17 小时前
配置 Redis
数据库·redis·缓存
u01091476019 小时前
CSS组件库如何快速扩展_通过Sass @extend继承基础布局
jvm·数据库·python
baidu_3409988220 小时前
Golang怎么用go-noescape优化性能_Golang如何使用编译器指令控制逃逸分析行为【进阶】
jvm·数据库·python
m0_6784854520 小时前
如何利用虚拟 DOM 实现无痕刷新?基于 VNode 对比的状态保持技巧
jvm·数据库·python
qq_3422958220 小时前
CSS如何实现透明背景效果_通过RGBA色彩模式控制透明度
jvm·数据库·python
panzer_maus20 小时前
MySQL 索引介绍与索引优化的简单介绍
数据库·mysql
Greyson120 小时前
CSS如何处理超长文本换行问题_结合word-wrap属性
jvm·数据库·python
captain37620 小时前
事务___
java·数据库·mysql
justjinji20 小时前
如何批量更新SQL数据表_使用UPDATE JOIN语法提升效率
jvm·数据库·python
北漂Zachary20 小时前
四大编程语言终极对比
android·java·php·laravel