ホームページ > バックエンド開発 > PHPチュートリアル > 如何快速实现mysql范围查询?

如何快速实现mysql范围查询?

WBOY
リリース: 2016-06-06 20:47:36
オリジナル
1544 人が閲覧しました

我有一堆的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掉.

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート