LINUX-MySQL索引管理

1.索引简介

|----------------|----------------------------------|
| 无索引 | 有索引 |
| 1.全表扫描(全局查找内容) | 1.索引扫描(按一定规律的查找内容) |
| | 优点 2.极大提高查询速度 3.确保数据唯一性 4.加速表间连接 |
| | 优点 2.极大提高查询速度 3.确保数据唯一性 4.加速表间连接 |
| | 优点 2.极大提高查询速度 3.确保数据唯一性 4.加速表间连接 |
| | 缺点 1.占用额外存储空间 2.降低数据写入速度 |
| 1.对于读多写少的应用,创建合适的索引是优化数据库查询性能最有效的手段之一 2.索引不是越多越好,需要根据实际创建 ||
[无索引与有索引]

|------|------------------------------|
| 普通索引 | 最基本索引,没有任何限制,仅用于加速查询 |
| 唯一索引 | 与普通索引类似,但要求索引列值唯一,允许空值 |
| 主键索引 | 一种特殊的唯一索引,不允许为空。一个表只能有一个主键索引 |
| 全文索引 | 用于全文搜索 |
[按逻辑功能划分索引]

|--------|-------------------------------------------|
| 创建普通索引 | ALTER TABLE 表名 ADD INDEX 索引名 (字段名); |
| 创建唯一索引 | ALTER TABLE 表名 ADD UNIQUE INDEX 索引名(字段名); |
| 创建主键索引 | ALTER TABLE 表名 ADD PRIMARY KEY(字段名); |
| 创建全文索引 | ALTER TABLE 表名 ADD FULLTEXT(字段名); |
| 删除索引 | ALTER TABLE 表名 DROP INDEX 索引名; |
| 查看索引 | SHOW INDEX FROM 表名;或者\G |
[索引语句]

2.有索引与无索引的差异

2.1创建测试环境

复制代码
create database cloud2026;

use cloud2026

CREATE TABLE students (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50),
    email VARCHAR(100),
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

DELIMITER //

CREATE PROCEDURE InsertLargeData()
BEGIN
    DECLARE i INT DEFAULT 1;
    WHILE i <= 1000000 DO
        INSERT INTO students (username, email)
        VALUES (CONCAT('user', i), CONCAT('user', i, '@126.com'));
        SET i = i + 1;
    END WHILE;
END//

DELIMITER ;

CALL InsertLargeData();

INSERT INTO students (username, email) VALUES ('NATASHA', 'NATASHA131420@126.com');

2.2无索引查询

2.3有索引查询

为username添加索引idx_username

复制代码
ALTER TABLE students ADD INDEX idx_username(username);
查看执行计划
复制代码
EXPLAIN SELECT * FROM students WHERE username="NATASHA"\G
相关推荐
小碗羊肉几秒前
【Redis | 第二篇】Jedis&SpringDataRedis
数据库·redis·缓存
郝学胜-神的一滴4 分钟前
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
java·数据库·python·缓存·php·软件构建
米高梅狮子5 分钟前
01.ELK企业日志分析系统
运维·服务器·网络·数据库·elk·oracle
小杍随笔8 分钟前
【redb vs SQLite (rusqlite) 技术选型对比】
数据库·sqlite
暗夜猎手-大魔王8 分钟前
转载--AI Agent 架构设计:工具返回值设计(OpenClaw、Claude Code、Hermes Agent 对比)
数据库
windawdaysss9 分钟前
离线学习SQL和数据库的工具及其部署
数据库·sql·学习
Rubin智造社10 分钟前
Claude Code开发者大会系列8:从脚本到智能体——独立开发者的“AI原生”工作流转型
数据库·人工智能·独立开发者·agentic工作流·ai原生开发·实操指南
一条泥憨鱼10 分钟前
深入理解 MySQL 索引:原理、分类与优化实战
数据库·mysql
楠枬10 分钟前
Redis 缓存
数据库·redis·缓存
一条泥憨鱼10 分钟前
详解MySQL事务(超详细版)
java·数据库·mysql·spring·maven·后端开发