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
相关推荐
m0_68450198几秒前
C#怎么使用LINQ Contains包含判断 C#如何用Contains实现类似SQL IN查询的集合包含判断【语法】
jvm·数据库·python
2301_7641505617 分钟前
c++如何读取和解析带BOM头的UTF-8与UTF-16文本流【详解】
jvm·数据库·python
qq_4240985621 分钟前
HTML函数开发用窄边框笔记本有优势吗_便携与性能权衡【指南】
jvm·数据库·python
Wyz2012102424 分钟前
CSS如何实现导航栏下划线随鼠标移动_利用-hover伪类与过渡动画控制
jvm·数据库·python
2201_7610405925 分钟前
SQL如何统计每个用户的首次行为时间_MIN聚合与分组
jvm·数据库·python
qq_1898070330 分钟前
mysql如何实现定时清理缓存数据_利用event scheduler执行
jvm·数据库·python
Polar__Star33 分钟前
golang如何实现低功耗设备唤醒机制_golang低功耗设备唤醒机制实现教程
jvm·数据库·python
a95114164234 分钟前
CSS怎么在flex布局中实现项目均分间距_设置justify-content space-evenly
jvm·数据库·python
2201_7610405941 分钟前
Golang如何做灰度发布_Golang灰度发布教程【实战】
jvm·数据库·python
小梦爱安全42 分钟前
SQL Server(Linux)安装
数据库·microsoft·sqlserver