mysql索引影响查询速度的示例demo

创建一个完整的索引影响查询速度的示例demo,通过实际对比可以直观感受索引的强大作用。

一、测试环境准备

1. 创建测试数据库和表

sql 复制代码
-- 创建测试数据库
CREATE DATABASE index_demo;
USE index_demo;

-- 创建用户表(无索引状态)
CREATE TABLE users_no_index (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL,
    age INT NOT NULL,
    city VARCHAR(50) NOT NULL,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

-- 创建用户表(有索引状态)
CREATE TABLE users_with_index (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL,
    age INT NOT NULL,
    city VARCHAR(50) NOT NULL,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    INDEX idx_username (username),
    INDEX idx_email (email),
    INDEX idx_age_city (age, city),
    INDEX idx_created_at (created_at)
);

2. 插入大量测试数据

sql 复制代码
-- 插入50万条测试数据
DELIMITER $$
CREATE PROCEDURE insert_test_data()
BEGIN
    DECLARE i INT DEFAULT 1;
    WHILE i <= 500000 DO
        INSERT INTO users_no_index (username, email, age, city) VALUES (
            CONCAT('user', i),
            CONCAT('user', i, '@example.com'),
            FLOOR(18 + RAND() * 50),
            ELT(FLOOR(1 + RAND() * 10), '北京', '上海', '广州', '深圳', '杭州', '南京', '武汉', '成都', '西安', '重庆')
        );
        
        INSERT INTO users_with_index (username, email, age, city) VALUES (
            CONCAT('user', i),
            CONCAT('user', i, '@example.com'),
            FLOOR(18 + RAND() * 50),
            ELT(FLOOR(1 + RAND() * 10), '北京', '上海', '广州', '深圳', '杭州', '南京', '武汉', '成都', '西安', '重庆')
        );
        
        IF i % 10000 = 0 THEN
            SELECT CONCAT('已插入 ', i, ' 条数据') AS progress;
        END IF;
        SET i = i + 1;
    END WHILE;
END$$
DELIMITER ;

-- 执行数据插入(这可能需要几分钟)
CALL insert_test_data();

二、性能对比测试

测试1:基本查询对比

sql 复制代码
mysql> SELECT * FROM users_no_index WHERE username = 'user110000';
+--------+------------+------------------------+-----+--------+---------------------+
| id     | username   | email                  | age | city   | created_at          |
+--------+------------+------------------------+-----+--------+---------------------+
| 110000 | user110000 | user110000@example.com |  36 | 北京   | 2025-12-27 16:33:15 |
+--------+------------+------------------------+-----+--------+---------------------+
1 row in set (0.08 sec)

mysql> SELECT * FROM users_with_index WHERE username = 'user110000';
+--------+------------+------------------------+-----+--------+---------------------+
| id     | username   | email                  | age | city   | created_at          |
+--------+------------+------------------------+-----+--------+---------------------+
| 110000 | user110000 | user110000@example.com |  66 | 成都   | 2025-12-27 16:33:15 |
+--------+------------+------------------------+-----+--------+---------------------+
1 row in set (0.00 sec)

测试2:精确的性能测量

sql 复制代码
mysql> SET profiling = 1;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> 
mysql> SELECT * FROM users_no_index WHERE username = 'user110000';
+--------+------------+------------------------+-----+--------+---------------------+
| id     | username   | email                  | age | city   | created_at          |
+--------+------------+------------------------+-----+--------+---------------------+
| 110000 | user110000 | user110000@example.com |  36 | 北京   | 2025-12-27 16:33:15 |
+--------+------------+------------------------+-----+--------+---------------------+
1 row in set (0.07 sec)

mysql> SHOW PROFILE FOR QUERY 1;
+--------------------------------+----------+
| Status                         | Duration |
+--------------------------------+----------+
| starting                       | 0.000094 |
| Executing hook on transaction  | 0.000006 |
| starting                       | 0.000034 |
| checking permissions           | 0.000006 |
| Opening tables                 | 0.000034 |
| init                           | 0.000011 |
| System lock                    | 0.000007 |
| optimizing                     | 0.000011 |
| statistics                     | 0.000022 |
| preparing                      | 0.000021 |
| executing                      | 0.073159 |
| end                            | 0.000040 |
| query end                      | 0.000004 |
| waiting for handler commit     | 0.000007 |
| closing tables                 | 0.000008 |
| freeing items                  | 0.000220 |
| cleaning up                    | 0.000018 |
+--------------------------------+----------+
17 rows in set, 1 warning (0.00 sec)

mysql> SELECT * FROM users_with_index WHERE username = 'user110000';
+--------+------------+------------------------+-----+--------+---------------------+
| id     | username   | email                  | age | city   | created_at          |
+--------+------------+------------------------+-----+--------+---------------------+
| 110000 | user110000 | user110000@example.com |  66 | 成都   | 2025-12-27 16:33:15 |
+--------+------------+------------------------+-----+--------+---------------------+
1 row in set (0.00 sec)

mysql> 
mysql> SHOW PROFILE FOR QUERY 2;
+--------------------------------+----------+
| Status                         | Duration |
+--------------------------------+----------+
| starting                       | 0.000096 |
| Executing hook on transaction  | 0.000006 |
| starting                       | 0.000005 |
| checking permissions           | 0.000005 |
| Opening tables                 | 0.000040 |
| init                           | 0.000005 |
| System lock                    | 0.000006 |
| optimizing                     | 0.000011 |
| statistics                     | 0.000089 |
| preparing                      | 0.000040 |
| executing                      | 0.000051 |
| end                            | 0.000005 |
| query end                      | 0.000005 |
| waiting for handler commit     | 0.000007 |
| closing tables                 | 0.000006 |
| freeing items                  | 0.000168 |
| cleaning up                    | 0.000012 |
+--------------------------------+----------+
17 rows in set, 1 warning (0.00 sec)

mysql> SHOW PROFILES;
+----------+------------+--------------------------------------------------------------+
| Query_ID | Duration   | Query                                                        |
+----------+------------+--------------------------------------------------------------+
|        1 | 0.07369975 | SELECT * FROM users_no_index WHERE username = 'user110000'   |
|        2 | 0.00055400 | SELECT * FROM users_with_index WHERE username = 'user110000' |
+----------+------------+--------------------------------------------------------------+
2 rows in set, 1 warning (0.00 sec)
相关推荐
洛豳枭薰6 小时前
Innodb一次更新动作
mysql
xcLeigh6 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
Fleshy数模7 小时前
MySQL 表创建全攻略:Navicat 图形化与 Xshell 命令行双模式实践
linux·mysql
Nandeska7 小时前
15、基于MySQL的组复制
数据库·mysql
AllData公司负责人8 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
醇氧9 小时前
【docker】mysql 8 的健康检查(Health Check)
mysql·docker·容器
lekami_兰9 小时前
MySQL 长事务:藏在业务里的性能 “隐形杀手”
数据库·mysql·go·长事务
爱学英语的程序员11 小时前
面试官:你了解过哪些数据库?
java·数据库·spring boot·sql·mysql·mybatis
·云扬·12 小时前
MySQL Redo Log落盘机制深度解析
数据库·mysql
码界筑梦坊12 小时前
330-基于Python的社交媒体舆情监控系统
python·mysql·信息可视化·数据分析·django·毕业设计·echarts