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. 什么情况下不适合使用索引
  • 当表中的数据量很小,且查询的数据比例很大时,可能不适合使用索引。
  • 经常进行大批量的插入、更新、删除操作时,索引的维护成本可能较高。
相关推荐
大模型玩家七七19 分钟前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草20 分钟前
redis-9-哨兵
数据库·redis·bootstrap
明哥说编程25 分钟前
Dataverse自定义表查询优化:D365集成大数据量提速实战【索引配置】
数据库·查询优化·dataverse·dataverse自定义表·索引配置·d365集成·大数据量提速
xiaowu08035 分钟前
C# 拆解 “显式接口实现 + 子类强类型扩展” 的设计思想
数据库·oracle
讯方洋哥1 小时前
HarmonyOS App开发——关系型数据库应用App开发
数据库·harmonyos
惊讶的猫1 小时前
Redis持久化介绍
数据库·redis·缓存
Apple_羊先森2 小时前
ORACLE数据库巡检SQL脚本--19、磁盘读次数最高的前5条SQL语句
数据库·sql·oracle
全栈前端老曹2 小时前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
神梦流2 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
让学习成为一种生活方式3 小时前
trf v4.09.1 安装与使用--生信工具42-version2
数据库