ホームページ >データベース >mysql チュートリアル >MySQL 検索結果を関連性によって並べ替える方法: 最初に一致を開始しますか?

MySQL 検索結果を関連性によって並べ替える方法: 最初に一致を開始しますか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-30 08:10:10385ブラウズ

How to Order MySQL Search Results by Relevance: Beginning Matches First?

関連性による MySQL 結果の並べ替え: 最も一致するものから

MySQL データベースでは、多くの場合、ライブ検索機能で関連性に基づいて結果を並べ替えます。デフォルトでは、結果はアルファベット順に並べられますが、検索文字列が単語の先頭に一致する結果を優先したい場合はどうすればよいでしょうか?

これを実現するには、CASE ステートメントとパターン マッチングを利用してカスタム ステートメントを作成できます。 order:

SELECT word
FROM words
WHERE word LIKE '%searchstring%'
ORDER BY CASE
    WHEN word LIKE 'searchstring%' THEN 1
    WHEN word LIKE '%searchstring' THEN 3
    ELSE 2
  END

このクエリは、検索文字列が単語の先頭に表示される結果に 1 の優先順位を割り当て、文字列が単語内で一致する結果に 3 の優先順位を割り当てます。

または、一致した文字列の位置に基づいて並べ替えるには、LOCATE 関数を使用できます。

SELECT word
FROM words
WHERE word LIKE '%searchstring%'
ORDER BY LOCATE('searchstring', word)

このクエリは、位置に基づいて結果を並べ替えます。

最後に、複数の単語が検索文字列に一致する同点の場合、二次的な並べ替えルールを追加して、各優先グループ内の結果をアルファベット順に並べることができます:

SELECT word
FROM words
WHERE word LIKE '%searchstring%'
ORDER BY <whatever>, word

検索文字列の位置に基づいてカスタム順序付けを実行することで、検索結果の関連性を強化し、ユーザー エクスペリエンスを向上させることができます。 .

以上がMySQL 検索結果を関連性によって並べ替える方法: 最初に一致を開始しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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