ホームページ > データベース > mysql チュートリアル > MySQL の FIND_IN_SET 関数でインデックスを利用するにはどうすればよいですか?

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

DDD
リリース: 2024-11-07 16:50:03
オリジナル
1071 人が閲覧しました

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

以上がMySQL の FIND_IN_SET 関数でインデックスを利用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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