ホームページ >バックエンド開発 >PHPチュートリアル >如何快速实现mysql范围查询?
我有一堆的id,高达几百上千个id,每个id在数据库中都有唯一对应的数据,我想快速查询出来这个结果集,但以我的知识只知道sql语句用 in(ids) 来查询,这种查询有500个id和有5000个id的效率差别是不是特别大啊?有没有其他方式能高效点?
情境:更新一张excel表格,里面有N条数据,是根据数据库里的数据来更新的。
我有一堆的id,高达几百上千个id,每个id在数据库中都有唯一对应的数据,我想快速查询出来这个结果集,但以我的知识只知道sql语句用 in(ids) 来查询,这种查询有500个id和有5000个id的效率差别是不是特别大啊?有没有其他方式能高效点?
情境:更新一张excel表格,里面有N条数据,是根据数据库里的数据来更新的。
我能想到的也就是两个方法, 1). 像你说的, in(ids); 2). 建临时表, 把id插进去, 然后做join.
就是这个网页里提到的:
http://explainextended.com/2009/08/18/passing-parameters-in-mysql-in-list-vs-temporary-table/
一般来说, 第二种好一些.
就我的理解来说,
第一种in list的方式, mysql会把你传入的id列表排序(排序后在内存中), 然后遍历 数据表, 用每一条记录去 二分查找你的 排序后的id列表; 这种工作方式是不会过索引的.
第二种, 临时表和 数据表做join, 数据表在ID字段上的索引是会被使用的.
附一点临时表使用:
<code>mysql> create temporary table if not exists $TMP (id int); Query OK, 0 rows affected, 1 warning (0.02 sec) mysql> insert into $TMP values(1),(2),(3),(4),(5); Query OK, 5 rows affected (0.05 sec) Records: 5 Duplicates: 0 Warnings: 0 </code>
断开连接后临时表被自动drop掉.