老俵哥 发表于 2016-9-28 10:49:47

MySQL 利用多线程提升查询性能的一种思路

问题描述:有张大表,按照时间查询,如果是一个月,查询时间120秒左右,如果是按天查询大概1-2秒左右。
请问:谁了解利用mysql开启多线程并发查询的方法?
例如:查询一个月数据,按照每天的sql并发30进行一次性查询得出结果。
求解!

13980908582 发表于 2016-9-28 17:06:51

据我了解,mysql不支持多线程处理同一个sql语句

13980908582 发表于 2016-9-28 17:09:04

你把sql语句贴出来,看下可以优化不。。表有多少行

老俵哥 发表于 2016-9-29 11:55:21

13980908582 发表于 2016-9-28 17:09
你把sql语句贴出来,看下可以优化不。。表有多少行


rows:11.78M
Data size :7.33G
Index size:5.34G
Total size :12.67G

t_flow_order 48个字段

select * from t_flow_order where order_date between '2016-08-01' and '2016-08-30'

13980908582 发表于 2016-9-29 16:45:02

你一定要查所有字段么?
如果你的字段可以单纯通过时间筛选,可以考虑根据时间分区啊。。
现在不分区的情况下,你试下延迟加载数据,order_date要加索引,也就是改成这种形式:
select * from t_flow_order where id in (select t_flow_order.id(表的主键) from t_flow_order where order_date between '2016-08-01' and '2016-08-30' );
我不确定效果咋样哈,给个建议

老俵哥 发表于 2016-9-30 14:06:45

13980908582 发表于 2016-9-29 16:45
你一定要查所有字段么?
如果你的字段可以单纯通过时间筛选,可以考虑根据时间分区啊。。
现在不分区的情 ...

首先,谢谢你的回答
我这个是一个查询页面,时间只是默认的查询条件,算算还有其他的7个查询条件。而且我这个页面还有个统计的功能,就是把所有的数据值加起来限制,主要慢就是慢在这个统计上,一天的统计很快,但如果一个月时间的统计就很慢了。所以想着能不能并发一次性按每天查询

页: [1]
查看完整版本: MySQL 利用多线程提升查询性能的一种思路