MySQL の FIND_IN_SET 関数はインデックスを利用しないことで悪名が高く、クエリが非効率になります。ただし、カンマ区切りリストを処理するときに、目的のインデックス作成動作を実現するための代替アプローチがあります。
提供された回答で説明されている手法では、パラメーターを指定した準備されたステートメントを使用することを提案しています。カンマ区切りリストの形式で文字列を受け入れます。準備されたステートメントで非 NULL キーを持つ範囲タイプを使用すると、IN 句の実行時にインデックスが確実に使用されます。
たとえば、次のクエリは、インデックスを使用して範囲検索を実行します。 「id」列:
explain select * from ratings where id in (2331425, 430364, 4557546, 2696638, 4510549, ...)
このアプローチでは効率的なインデックス付きクエリが可能ですが、次の予防措置を考慮することが重要です:
以上がMySQL の FIND_IN_SET 関数でインデックスを利用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。