Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Como obter todo o registro sem remover no grupo no mysql


Se você estiver usando o MySQL 8+, podemos lidar com isso usando ROW_NUMBER :
WITH cte AS (
    SELECT *, ROW_NUMBER() OVER (PARTITION BY Date ORDER BY Time) rn
    FROM attendancedata
    WHERE EnrolledID = 23
)

SELECT
    Date,
    MAX(CASE WHEN rn = 1 THEN Time END) AS PO1,
    MAX(CASE WHEN rn = 2 THEN Time END) AS PO2,
    MAX(CASE WHEN rn = 3 THEN Time END) AS PO3,
    MAX(CASE WHEN rn = 4 THEN Time END) AS PO4,
    MAX(CASE WHEN rn = 5 THEN Time END) AS PO5,
    MAX(CASE WHEN rn = 6 THEN Time END) AS PO6,
    MAX(CASE WHEN rn = 7 THEN Time END) AS PO7
FROM cte
GROUP BY
    Date
ORDER BY
    Date;

Mas observe que, em geral, é desejável armazenar data e hora em um único datetime campo com MySQL. Neste caso em particular, funcionou bem, mas isso nem sempre pode ser verdade.