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
相关推荐
山岚的运维笔记19 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里20 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科20 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦20 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
晚霞的不甘21 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位21 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全
海奥华221 小时前
mysql索引
数据库·mysql
2601_949593651 天前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__1 天前
mysql新老项目版本选择
数据库·mysql
Dxy12393102161 天前
MySQL如何高效查询表数据量:从基础到进阶的优化指南
数据库·mysql