MySQL-索引的介绍和使用

MySQL 支持哪些类型的索引?

主键索引(Primary Key Index)

唯一索引(Unique Index)

普通索引(Normal Index)

全文索引(Full-text Index)

组合索引(Composite Index)


1. 索引的使用

  1. 创建索引
    使用 CREATE INDEX 语句或在创建表时直接指定索引。
bash 复制代码
-- 创建单列索引
CREATE INDEX index_name ON table_name(column_name);

-- 创建唯一索引
CREATE UNIQUE INDEX index_name ON table_name(column_name);

-- 创建组合索引
CREATE INDEX index_name ON table_name(column1, column2);
  1. 查看索引
bash 复制代码
SHOW INDEX FROM table_name;
  1. 删除索引
    -- 删除表的某个索引
bash 复制代码
DROP INDEX index_name ON table_name;

-- 删除表的主键索引

bash 复制代码
ALTER TABLE table_name DROP PRIMARY KEY;
  1. 使用 EXPLAIN 分析查询执行计划
bash 复制代码
EXPLAIN SELECT * FROM table_name WHERE column_name = 'value';
  1. 如何优化查询,使索引生效
  • 确保查询中的条件列上有索引。
  • 尽量避免在索引列上使用函数或运算符。
  • 使用合适的索引类型,如全文索引适用于文本搜索。
  1. 如何避免索引失效?
  • 尽量避免使用 NOT、<、>、!= 等不利于索引的条件。
  • 注意索引列的数据类型匹配。
  • 小心使用 OR 连接的条件。
  1. 什么情况下不适合使用索引
  • 当表中的数据量很小,且查询的数据比例很大时,可能不适合使用索引。
  • 经常进行大批量的插入、更新、删除操作时,索引的维护成本可能较高。
相关推荐
MrJson-架构师13 分钟前
4.银河麒麟V10(ARM) 离线安装 MySQL
arm开发·mysql
中草药z29 分钟前
【Spring】深入解析 Spring 原理:Bean 的多方面剖析(源码阅读)
java·数据库·spring boot·spring·bean·源码阅读
地球资源数据云30 分钟前
全国30米分辨率逐年植被覆盖度(FVC)数据集
大数据·运维·服务器·数据库·均值算法
Ahern_1 小时前
Oracle 普通表至分区表的分区交换
大数据·数据库·sql·oracle
夜半被帅醒1 小时前
MySQL 数据库优化详解【Java数据库调优】
java·数据库·mysql
不爱学习的啊Biao2 小时前
【13】MySQL如何选择合适的索引?
android·数据库·mysql
破 风2 小时前
SpringBoot 集成 MongoDB
数据库·mongodb
Rverdoser2 小时前
MySQL-MVCC(多版本并发控制)
数据库·mysql
醒了就刷牙2 小时前
黑马Java面试教程_P9_MySQL
java·mysql·面试
m0_748233642 小时前
SQL数组常用函数记录(Map篇)
java·数据库·sql