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

Datum der MySQL-Pivot-Tabelle (vertikale zu horizontalen Daten)

Um dieses Ergebnis zu erhalten, sollten Sie schwenken die Daten. MySQL hat keine Pivot-Funktion, aber Sie können eine Aggregatfunktion mit einem CASE verwenden Ausdruck.

Wenn die Anzahl der Daten bekannt ist, können Sie die Abfrage fest codieren:

select client_id,
  max(case when rownum = 1 then date end) Date1,
  max(case when rownum = 2 then date end) Date2,
  max(case when rownum = 3 then date end) Date3
from
(
  select client_id,
    date,
    @row:=if(@prev=client_id, @row,0) + 1 as rownum,
    @prev:=client_id 
  from yourtable, (SELECT @row:=0, @prev:=null) r
  order by client_id, date
) s
group by client_id
order by client_id, date

Siehe SQL-Geige mit Demo

Ich habe Benutzervariablen implementiert, um jedem Datensatz innerhalb der client_id eine Zeilennummer zuzuweisen Gruppe.

Wenn Sie eine unbekannte Anzahl von Daten haben, müssen Sie eine vorbereitete Anweisung verwenden, um die SQL dynamisch zu erstellen:

SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'MAX(CASE WHEN rownum = ',
      rownum,
      ' THEN date END) AS Date_',
      rownum
    )
  ) INTO @sql
from
(
  select client_id,
    date,
    @row:=if(@prev=client_id, @row,0) + 1 as rownum,
    @prev:=client_id 
  from yourtable, (SELECT @row:=0) r
  order by client_id, date
) s
order by client_id, date;


SET @sql 
  = CONCAT('SELECT client_id, ', @sql, ' 
           from
           (
             select client_id,
               date,
               @row:=if(@prev=client_id, @row,0) + 1 as rownum,
               @prev:=client_id 
             from yourtable, (SELECT @row:=0) r
             order by client_id, date
           ) s
           group by client_id
           order by client_id, date');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

Siehe SQL Fiddle mit Demo .

Beide geben das Ergebnis:

| CLIENT_ID |                          DATE_1 |                          DATE_2 |                     DATE_3 |
--------------------------------------------------------------------------------------------------------------
|         1 | February, 03 2013 00:00:00+0000 | February, 10 2013 00:00:00+0000 | May, 12 2013 00:00:00+0000 |
|         2 | February, 03 2013 00:00:00+0000 |     July, 15 2013 00:00:00+0000 |                     (null) |