我有一个来自单个表的非常简单的查询(三个where条件;两个等于,一个介于之间),在MySQL查询浏览器中,查询运行不到半秒钟,返回8300条记录。如果我使用mysql数据连接器(实际上只是一个OLEDB包装器)运行完全相同的查询,则需要大约35秒。
使用的发动机是Myisam(如果这很重要的话)。我正在使用Visual Studio 2008(如果这很重要的话)。编辑:使用MySQL数据连接器5.2.5。编辑,编辑:切换到MySQL数据连接器6.0.3(最新版本)将其缩短到29秒。
查询是:
select drh_data.reading_time, drh_data.raw_value, drh_data.float_value, drh_data.data_quality
from drh_data
where drh_data.site_id=202
and drh_data.device_id=7
and reading_time between '2009-04-08 11:15:01' and '2009-05-08 11:15:02'
order by drh_data.reading_time desc;
有什么想法吗?
更新:我终于开始检查CPU的使用情况(根据一个回答者的建议),发现我的应用程序使用了50%的CPU时间。运行mysql的virtualpc设备(在CentOS中)在这20秒(大约)的时间内有0%,所以问题都在客户端。我还对这个问题进行了解释,结果是:
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE drh_data range PRIMARY,idx_site_device_reading_receive idx_site_device_reading_receive 11 7674 Using where
我被解雇了。有人想解决这个问题吗?我正打算通过限制来打破选择,但我不认为我必须这么做。