代码之家  ›  专栏  ›  技术社区  ›  Michael Todd

为什么mysql数据连接器比mysql查询浏览器花的时间长?

  •  2
  • Michael Todd  · 技术社区  · 15 年前

    我有一个来自单个表的非常简单的查询(三个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
    

    我被解雇了。有人想解决这个问题吗?我正打算通过限制来打破选择,但我不认为我必须这么做。

    2 回复  |  直到 15 年前
        1
  •  1
  •   inkredibl    15 年前

    我建议检查一下这几秒钟的工作(CPU使用率),是MySQL还是您的代码或其他什么东西。您也可以考虑使用 EXPLAIN 看看在一个或另一个案例中发生了什么,并比较它们。

        2
  •  1
  •   Scott Lance    15 年前

    在使用ADO.NET和SQL Server查询分析器之前,我遇到了这个问题。当我们从查询分析器运行查询时,查询在第二秒执行,当我们从Web应用程序运行查询时,需要2分钟以上的时间。无论出于什么原因,将索引应用于表似乎都可以加速应用程序和数据库之间的数据连接。

    我不知道MySQL和SQL Server之间的操作差异,但在我们的案例中似乎发生了另一件事,那就是执行缓存已满,并且所有未缓存的执行计划的执行速度都在减慢。我们每周执行一个清除缓存的作业。