「LIKE」とワイルドカードによる MySQL 検索効率の改善
問題: 「SELECT * FROM sometable」などのクエリWHERE somefield LIKE '%value%'" は先頭にあるため非効率的ですワイルドカードがインデックスの使用を妨げています。
解決策: 接尾辞配列のインデックス作成
比較的短い文字列の場合は、各単語の可能なすべての接尾辞をデータベースに保存することを検討してください。たとえば、単語「value」の場合、次のように格納します。
value alue lue ue e
サフィックスを格納することで、先頭のワイルドカードを削除し、高速な部分文字列検索でインデックスを使用できるようにします。
ストレージ コスト:
サフィックスの保存に必要なストレージ スペースは、文字列の増加に応じて二次関数的に増加します。 長さ。例:
考慮事項:
以上がサフィックス配列インデックス作成により、ワイルドカードを使用した MySQL の「LIKE」クエリをどのように強化できるでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。