Mysql
 sql >> Datenbank >  >> RDS >> Mysql

MySQL group_concat() sortiert nach case-Anweisungswerten

Sie können dies erreichen, indem Sie nach Spaltenposition ordnen anstelle von Spaltenname .

Für Ihren Fall ORDER BY 1 sollte funktionieren.

SELECT 
  things.id
  ,group_concat(DISTINCT 
    CASE
    WHEN things.name <> 'United States' THEN 'Non-US'
    WHEN things.name IS NULL THEN 'Unknown'
    ELSE things.name
    END
  ORDER BY 1 SEPARATOR ', ')
FROM things
GROUP BY things.id