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 » Joinery Administration » Organization
内で ORDER BY 句を指定することにより、サブクエリでは、連結された値のシーケンスを制御できます。これにより、カスタマイズされた順序で結果を表示する柔軟な方法が提供され、結果がより読みやすく整理されます。
ORDER BY 句は、GROUP_CONCAT() に続くサブクエリのかっこ内に配置する必要があることに注意してください。これにより、MySQL は値を 1 つの文字列に連結する前に並べ替えることができます。
以上がMySQL GROUP_CONCAT ステートメントの値をソートするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。