「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > MySQL の FIND_IN_SET 関数でインデックスを利用するにはどうすればよいですか?

MySQL の FIND_IN_SET 関数でインデックスを利用するにはどうすればよいですか?

2024 年 11 月 12 日に公開
ブラウズ:333

How Can I Make MySQL's FIND_IN_SET Function Utilize Indices?

MySQL FIND_IN_SET でインデックスを使用できるようにできますか?

MySQL の FIND_IN_SET 関数はインデックスを利用しないことで悪名が高く、クエリが非効率になります。ただし、カンマ区切りリストを処理するときに必要なインデックス作成動作を実現するための別のアプローチがあります。

範囲アプローチ

提供された回答で説明されている手法では、パラメーターを指定した準備されたステートメントを使用することを提案しています。カンマ区切りリストの形式で文字列を受け入れます。プリペアド ステートメントで非 NULL キーを持つ範囲タイプを使用すると、IN 句の実行時にインデックスが確実に使用されます。

たとえば、次のクエリは、インデックスを使用して範囲検索を実行します。 「id」列:

explain 
select * from ratings where id in (2331425, 430364, 4557546, 2696638, 4510549, ...)

注意事項と警告

このアプローチでは効率的なインデックス付きクエリが可能ですが、次のことが重要です。次の予防措置を考慮してください:

  • SQL インジェクション攻撃: ストアド プロシージャでユーザーが指定したデータを使用すると、SQL インジェクション攻撃への道が開かれる可能性があります。悪意のあるコードの実行を防ぐには、適切なサニタイズが不可欠です。
  • Tablescans: 範囲検索に使用される列にインデックスが付けられていない場合、または null 以外の値が含まれている場合、恐ろしいテーブル スキャンが発生する可能性があります。これは、大規模なデータセットの場合は非常に非効率的です。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3