Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Butuh bantuan untuk unpivot di mysql dengan beberapa kolom tanggal

Saya menguji yang berikut ini di MySQL 8.0.1:

SELECT GROUP_CONCAT(
  CONCAT(
    'SELECT `Product Type`, ', 
       QUOTE(COLUMN_NAME), ' AS `Date`, ',
       '`', COLUMN_NAME, '` AS `Revenue` ',
    'FROM testing_unpivot'
  ) SEPARATOR ' UNION ALL '
)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'testing_unpivot'
AND COLUMN_NAME <> 'Product Type';

Menggunakan fungsi QUOTE() membuatnya lebih sederhana, karena menghilangkan kebutuhan untuk mengetahui tanda kutip triple vs. quad.

Keluaran:

SELECT `Product Type`, '01-31-2016' AS `Date`, `01-31-2016` AS `Revenue` FROM testing_unpivot 
UNION ALL 
SELECT `Product Type`, '02-29-2016' AS `Date`, `02-29-2016` AS `Revenue` FROM testing_unpivot 
UNION ALL 
SELECT `Product Type`, '12-31-2015' AS `Date`, `12-31-2015` AS `Revenue` FROM testing_unpivot

Kemudian saya melakukan salin &tempel untuk menjalankan kueri itu dan mendapatkan hasil ini:

+--------------+------------+---------+
| Product Type | Date       | Revenue |
+--------------+------------+---------+
| A            | 01-31-2016 |  400.00 |
| B            | 01-31-2016 |   86.88 |
| C            | 01-31-2016 |  400.00 |
| D            | 01-31-2016 |   55.00 |
| E            | 01-31-2016 |  455.00 |
| A            | 02-29-2016 |   55.00 |
| B            | 02-29-2016 |   55.00 |
| C            | 02-29-2016 |   55.00 |
| D            | 02-29-2016 |   11.00 |
| E            | 02-29-2016 |   22.00 |
| A            | 12-31-2015 |  100.00 |
| B            | 12-31-2015 |    0.00 |
| C            | 12-31-2015 |  200.00 |
| D            | 12-31-2015 |  300.00 |
| E            | 12-31-2015 |  400.00 |
+--------------+------------+---------+

Saya baru saja memuat data pengujian saya dengan data senilai tiga tanggal pertama Anda.




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. BULAN () Contoh – MySQL

  2. Saya ingin menyalin tabel yang terdapat dari satu database dan menyisipkan ke tabel database lain

  3. doktrin2 - Bagaimana cara meningkatkan efisiensi flush?

  4. Bagaimana cara membandingkan string versi (x.y.z) di MySQL?

  5. Cara membuat General Ledger/T-Account menggunakan PHP Mysql