遇见的问题:30W查询速度慢
mysql版本:5.7
内存:1G
CPU:1核
mysql的一些配置:
innodb_buffer_pool_size:134217728 ( 128M)
key_buffer_size:16777216 ( 16M)
sort_buffer_size:720896(704K)
tmp_table_size:16M 默认为16M 调到64-256最挂
max_connections:2532
查询的SQL语句:
select count(*) as aggregate from `dtk_products` where `is_display` = 1 and `Cid` = 1 and `Quan_timestamp` > 1546411307 and `Quan_surplus` > 0
数据量:近30W
无条件统计:耗时542ms
data:image/s3,"s3://crabby-images/f8c76/f8c7630260bb6ba005a86107b85a5765d55fc56d" alt=""
未创建索引
使用以上SQL查询(4个字段条件):执行耗时14.6s
data:image/s3,"s3://crabby-images/861b1/861b14a492426cb27bf798c7d9a29605f9d0c6f7" alt=""
data:image/s3,"s3://crabby-images/1ee5f/1ee5f2e6d2cf3543c95a71d5dc331c565f220f0d" alt=""
创建4个字段的单独索引
is_display Cid Quan_timestamp Quan_surplus
data:image/s3,"s3://crabby-images/46e67/46e67f0c7dc26812139cc83869d96d9e3eb0fe7e" alt=""
执行SQL统计:耗时12.5s
data:image/s3,"s3://crabby-images/d8b39/d8b39295b124a3431318940a86a468859c8cd1b3" alt=""
创建联合索引
执行SQL统计:耗时25.9s
data:image/s3,"s3://crabby-images/5f374/5f37478ee6ccb95e9f84e69a8c64f613cf2640f5" alt=""
data:image/s3,"s3://crabby-images/0c5cd/0c5cd8409b669a6b1eb65007509b932d25cdb862" alt=""
通过图7 和图4的 索引情况对比,不难发现,字段Quan_timestamp 和Quan_surplus的索引基数(Cardinality)差别很大。
结论:索引基数越高,查询效率越高。联合索引的索引基数比较大
PS:
耗时:148ms
data:image/s3,"s3://crabby-images/eba8b/eba8b3fa2c99ca54b9ba33cf6451e5cde032ebda" alt=""
数据量:308553
data:image/s3,"s3://crabby-images/37575/37575068f079fefc54f61ef4b37efd4f037fc027" alt=""
Explain SQL:结果如下 type=range ;key=4个字段的联合索引
data:image/s3,"s3://crabby-images/22684/2268466b665baf8e43e3d6ce6596e848950fef3c" alt=""
该表字段共37个,包含数据类型:int archer decimal timestamp
网友评论