ホームページ  >  記事  >  バックエンド開発  >  javascript - 複数テーブルの関連付けクエリ ステートメントに巨大なユーザー ID 配列を入れると、クエリに時間がかかりすぎます。最適化するにはどうすればよいですか?

javascript - 複数テーブルの関連付けクエリ ステートメントに巨大なユーザー ID 配列を入れると、クエリに時間がかかりすぎます。最適化するにはどうすればよいですか?

WBOY
WBOYオリジナル
2016-12-05 13:44:301440ブラウズ

複数テーブルの関連付けクエリ ステートメントで、巨大なユーザー ID 配列を配置するとクエリ時間が長すぎます。最適化するにはどうすればよいですか?

1. クエリ文は以下の通りで、実行時間は147.4msです。

javascript - 複数テーブルの関連付けクエリ ステートメントに巨大なユーザー ID 配列を入れると、クエリに時間がかかりすぎます。最適化するにはどうすればよいですか?

返信内容:

複数テーブルの関連付けクエリ ステートメントで、巨大なユーザー ID 配列を配置するとクエリ時間が長すぎます。最適化するにはどうすればよいですか?

1. クエリ文は以下の通りで、実行時間は147.4msです。

javascript - 複数テーブルの関連付けクエリ ステートメントに巨大なユーザー ID 配列を入れると、クエリに時間がかかりすぎます。最適化するにはどうすればよいですか?

WHERE id IN (1,2,3)相当于WHERE id = 1 OR id = 2 OR id =3
OR条件が非常に多いため、IDのインデックスが遅くても正常です。

この問題の根本的な原因は、テーブル構造の設計が不合理であることです。クエリの最適化も永続的な解決策ではなく、一時的な解決策です
そのため、構造を設計する際にはあまり心配しないでください
さらに、EXPLAIN をより頻繁に使用してください

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。