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
相关推荐
悟能不能悟2 小时前
oracle date类型默认to_char会是什么形式
数据库·oracle
正在走向自律2 小时前
国产时序数据库实战,金仓如何破解电力行业数据困局
数据库·时序数据库·电科金仓
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue校园实验室管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
闲人不梦卿2 小时前
数据库之并发控制
数据库·事务
warton882 小时前
proxysql配置mysql mgr代理,实现读写分离
linux·运维·数据库·mysql
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-核心模块的数据模型交互关系
java·数据库·人工智能·spring boot·交互
短剑重铸之日2 小时前
7天读懂MySQL|特别篇:MVCC详解
数据库·后端·mysql·mvcc
北邮刘老师3 小时前
从SEO到ADO:智能体时代的流量密码
服务器·网络·数据库·人工智能·大模型·智能体·智能体互联网
javachen__3 小时前
mysql系统级文件损坏修复
数据库·mysql