ホームページ >データベース >mysql チュートリアル >MySQL GROUP_CONCAT ステートメントの値をソートするにはどうすればよいですか?

MySQL GROUP_CONCAT ステートメントの値をソートするにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-19 10:24:02518ブラウズ

How do I sort values in a MySQL GROUP_CONCAT statement?

MySQL GROUP_CONCAT での値の並べ替え

MySQL では、GROUP_CONCAT() 関数はテーブルの値を連結し、特定のカラムごとにグループ化します。ただし、デフォルトの動作では、テーブルに表示される順序で値が出力されます。これは、特に連結された値を並べ替える必要がある場合には、常に望ましい結果になるとは限りません。

GROUP_CONCAT ステートメント内の値を並べ替えるには、サブクエリ内で ORDER BY 句を使用できます。たとえば、次のクエリについて考えてみましょう。

GROUP_CONCAT((SELECT GROUP_CONCAT(parent.name SEPARATOR " » ")
FROM test_competence AS node, test_competence AS parent
WHERE node.lft BETWEEN parent.lft AND parent.rgt
  AND node.id = l.competence
  AND parent.id != 1
ORDER BY parent.lft) SEPARATOR "<br /><\n") AS competences

このクエリは、親コンピテンス名の連結値を昇順で並べ替えて返します。

Crafts &raquo; Joinery

Administration &raquo; Organization

内で ORDER BY 句を指定することにより、サブクエリでは、連結された値のシーケンスを制御できます。これにより、カスタマイズされた順序で結果を表示する柔軟な方法が提供され、結果がより読みやすく整理されます。

ORDER BY 句は、GROUP_CONCAT() に続くサブクエリのかっこ内に配置する必要があることに注意してください。これにより、MySQL は値を 1 つの文字列に連結する前に並べ替えることができます。

以上がMySQL GROUP_CONCAT ステートメントの値をソートするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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