関連性による 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 サイトの他の関連記事を参照してください。