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

Comment convertir des lignes en colonnes dans SQL Server ?

Une agrégation simple devrait faire :

select id,
    max(case when flag = 'I' then datetime end) indatetime,
    max(case when flag = 'O' then datetime end) outdatetime
from t
group by id;

Ou Si vous le souhaitez, vous pouvez utiliser pivot :

select id, [I] indatetime, [O] outdatetime
from t pivot (
    max(datetime) for flag in ([I],[O])
) as p