PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

transformer la valeur distincte des colonnes en lignes postgres

Vous pouvez utiliser l'agrégation conditionnelle :

select ad_id,
       max(case when name = 'name' then valueofname end) as name,
       max(case when name = 'age' then valueofname end) as age,
       max(case when name = 'birthday' then valueofname end) as birthday,
       max(case when name = 'job' then valueofname end) as job
from t
group by ad_id;

Dans SQL Server, vous pouvez également faire quelque chose de similaire avec pivot .