使用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
推荐阅读
-
细化解析:备份MySQL数据库的另类方法_MySQL
-
MySQL索引的缺点以及MySQL索引在实际操作中有哪些事项
-
mysql中游标在存储过程中的详细用法_MySQL
-
mysql的数据库常用操作(添加用户)_MySQL
-
MySQL 5安装过程中遇到的问题的解决
-
完美解决,不用重装:MySQL启动失败提示:本地计算机上的Mysql服务启动后停止
-
c#几种数据库的大数据批量插入(SqlServer、Oracle、SQLite和MySql)
-
MySQL数据库命令下的常用操作方法演示与介绍~
-
C#在MySQL大量数据下的高效读取、写入详解
-
源代码编译MYSQL5.6环境下的MHA+KEEPALIVED的安装和维护