Heim > Datenbank > MySQL-Tutorial > 使用mysql的困惑_MySQL

使用mysql的困惑_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-01 13:34:10
Original
996 Leute haben es durchsucht

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)
Nach dem Login kopieren

 

运行后发现耗时五十多秒。然后我被迫不用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)
Nach dem Login kopieren

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

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

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

 

bitsCN.com
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage