sql >> Database >  >> RDS >> Mysql

mysql draaitabeldatum (verticale naar horizontale gegevens)

Om dit resultaat te krijgen, moet je draaien de data. MySQL heeft geen spilfunctie, maar u kunt een aggregatiefunctie gebruiken met een CASE uitdrukking.

Als het aantal datums bekend is, kunt u de zoekopdracht hardcoderen:

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

Zie SQL Fiddle met demo

Ik heb gebruikersvariabelen geïmplementeerd om een ​​rijnummer toe te wijzen aan elk record binnen de client_id groep.

Als u een onbekend aantal datums heeft, moet u een voorbereide instructie gebruiken om de sql dynamisch te maken:

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;

Zie SQL Fiddle met demo .

Ze geven allebei het resultaat:

| 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) |



  1. Sql Server Service Broker-gespreksgroepen

  2. MySQL JOIN om ID's te vervangen door waarde uit een andere tabel

  3. Hoe verwijder je MySQL van Mac OS X?

  4. WordPress Meta Query-arrays