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

Gruppieren nach LIKE eines Spaltenwerts

Sie können case verwenden :

SELECT (CASE WHEN plan_type LIKE 'silver%' THEN 'silver'
             WHEN plan_type LIKE 'gold%' THEN 'gold'
             WHEN plan_type LIKE 'platinum%' THEN 'platinum'
        END) as plan_grp, COUNT(*)
FROM subscriptions
GROUP by (CASE WHEN plan_type LIKE 'silver%' THEN 'silver'
               WHEN plan_type LIKE 'gold%' THEN 'gold'
               WHEN plan_type LIKE 'platinum%' THEN 'platinum'
          END);

Bei einigen Datenbanken können Sie einen Spaltenalias in GROUP BY verwenden .