使用mysql的困惑_MySQL
程序员文章站
2022-04-08 12:32:46
...
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
上一篇: PHP的类的自动加载
推荐阅读
-
hibernate与mysql进行大文件的存储实例教程
-
删除Mysql的MySql-bin.0000X日志文件的方法
-
mysql统计总数条件判断的方法介绍
-
Ubuntu14.04服务器环境下配置PHP7.0+Apache2+Mysql5.7的方法
-
php与mysql建立连接并执行SQL语句的代码
-
PHP 获取MySQL数据库里所有表的实现代码
-
MySQL常见的8种SQL错误用法
-
MySql带OR关键字的多条件查询语句
-
Mysql误操作后利用binlog2sql快速回滚的方法详解
-
mysql报错:Deadlock found when trying to get lock; try restarting transaction的解决方法