欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

使用mysql的困惑_MySQL

程序员文章站 2022-04-28 21:42:45
...
bitsCN.com

  偶然我发现一个mysql的神奇的地方,看如下查询语句

SELECT gps_id,pu_index_code,time,longitude,latitude,direction,speed FROM gps_20130604 WHERE gps_id in(SELECT MAX(gps_id) from gps_20130604 GROUP BY pu_index_code)

运行后发现耗时五十多秒。然后我*不用in,用代码里循环的方式解决了慢的问题。

  但是这让我有些不爽,我本意是想一次数据库连接取出所有的符合条件的id号,用代码循环的话就要连接数据库1+n次。

  经过百度,我找到了答案,网址:mysql in优化。

  现在,我用

SELECT gps_id,pu_index_code,time,longitude,latitude,direction,speed FROM gps_20130604 WHERE gps_id in(select id from (SELECT MAX(gps_id) as id from gps_20130604 GROUP BY pu_index_code) as a)

解决了查询慢的问题,耗时平均0.002秒。

  经过研究,在mssql里是不存在这种问题的,直接用第一种sql语句就很快了。其他的如oracle那些还没有去试过。

  现在问题是解决了,但是mysql出现这种问题的原因是什么我还没有找出来。

bitsCN.com
相关标签: direction mysql