首先,使用Talend随机生成一千万条数据:

mysql性能测试(索引)

数据库表中现在有1千万+的数据:

mysql> select count(*) from zhangchao;
+----------+
| count(*) |
+----------+
| 10040005 |
+----------+
1 row in set (2.50 sec)

不加索引的情况下,查询一条记录的时间为3.02s

mysql> select * from zhangchao where x = "bq2i2T";
+--------+--------+
| x      | y      |
+--------+--------+
| bq2i2T | DRt5Mx |
+--------+--------+
1 row in set (3.02 sec)

mysql> show create table zhangchao;
+-----------+------------------------------------------------------------------------------------------------------------------------------------+
| Table     | Create Table                                                                                                                       |
+-----------+------------------------------------------------------------------------------------------------------------------------------------+
| zhangchao | CREATE TABLE `zhangchao` (
  `x` varchar(100) DEFAULT NULL,
  `y` varchar(100) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
+-----------+------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

给表zhangchao的x列创建索引,耗时45.43s:

mysql> alter table zhangchao add index (x);
Query OK, 0 rows affected (45.43 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> show create table zhangchao;
+-----------+-----------------------------------------------------------------------------------------------------------------------------------------------------+
| Table     | Create Table                                                                                                                                        |
+-----------+-----------------------------------------------------------------------------------------------------------------------------------------------------+
| zhangchao | CREATE TABLE `zhangchao` (
  `x` varchar(100) DEFAULT NULL,
  `y` varchar(100) DEFAULT NULL,
  KEY `x` (`x`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
+-----------+-----------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

在执行同样的查询,耗时0.09s:

mysql> select * from zhangchao where x = "bq2i2T";
+--------+--------+
| x      | y      |
+--------+--------+
| bq2i2T | DRt5Mx |
+--------+--------+
1 row in set (0.09 sec)

和没有加索引的性能差别:3.02/0.09 = 33.555倍

 

 

 

 

 

相关文章:

  • 2021-10-18
  • 2021-05-16
  • 2021-11-23
  • 2021-05-28
  • 2021-04-08
  • 2021-11-03
  • 2022-01-04
  • 2021-07-26
猜你喜欢
  • 2022-02-07
  • 2022-12-23
  • 2022-12-23
  • 2021-05-31
  • 2021-12-30
  • 2021-09-15
  • 2021-07-20
相关资源
相似解决方案