Pertanyaan MySQL untuk Menukar Baris kepada Lajur Berdasarkan Berbilang Lajur
Pengenalan:
Secara dinamik menukar baris kepada lajur adalah tugas biasa dalam manipulasi data. Dalam artikel ini, kami meneroka penyelesaian menggunakan pertanyaan MySQL, memperluaskan keupayaan penyelesaian sebelumnya yang mengendalikan penukaran satu lajur.
Masalah:
Anda mempunyai jadual dengan berbilang baris yang mewakili data dan harga yang sepadan, disusun mengikut pesanan dan item. Matlamatnya adalah untuk mengubah data ini menjadi jadual di mana setiap pesanan diwakili sebagai lajur dan setiap item diwakili sebagai baris, dengan harga yang sepadan dipaparkan.
Penyelesaian:
Untuk mencapai penukaran berbilang lajur ini, kami menggunakan proses dua langkah.
Langkah 1: Nyahpaut Data
Kami bermula dengan menyahpangsi data menggunakan UNION ALL untuk membuat berbilang baris bagi setiap gabungan pesanan dan item. Ini membolehkan kami memanipulasi data dengan lebih mudah dalam langkah seterusnya.
SELECT id, CONCAT('order', `order`) col, data value FROM tableA UNION ALL SELECT id, CONCAT('item', item) col, price value FROM tableA;
Langkah 2: Memutar Data Tidak Dipangsi
Setelah data dinyahpangsi, kami memutar ia kembali ke lajur menggunakan fungsi agregat dengan penyata CASE. Ini mengumpulkan baris yang tidak diputar mengikut ID dan memberikan nilai yang sepadan kepada lajur yang sesuai.
SELECT id, MAX(CASE WHEN col = 'order1' THEN value END) ORDER1, MAX(CASE WHEN col = 'order2' THEN value END) ORDER2, MAX(CASE WHEN col = 'order3' THEN value END) ORDER3, MAX(CASE WHEN col = 'item1' THEN value END) ITEM1, MAX(CASE WHEN col = 'item2' THEN value END) ITEM2, MAX(CASE WHEN col = 'item3' THEN value END) ITEM3 FROM ( SELECT id, CONCAT('order', `order`) col, data value FROM tableA UNION ALL SELECT id, CONCAT('item', item) col, price value FROM tableA ) d GROUP BY id;
Penjanaan Pertanyaan Dinamik:
Untuk mengendalikan jadual dengan bilangan pesanan yang berbeza-beza dan item, kita boleh menjana pertanyaan secara dinamik menggunakan disediakan pernyataan.
SET @sql = NULL; SELECT GROUP_CONCAT(DISTINCT CONCAT( 'MAX(CASE WHEN col = ''', col, ''' THEN value END) AS `', col, '`') ) INTO @sql FROM ( SELECT CONCAT('order', `order`) col FROM tableA UNION ALL SELECT CONCAT('item', `item`) col FROM tableA )d; SET @sql = CONCAT('SELECT id, ', @sql, ' FROM ( SELECT id, CONCAT(''order'', `order`) col, data value FROM tableA UNION ALL SELECT id, CONCAT(''item'', item) col, price value FROM tableA ) d GROUP BY id'); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt;
Keputusan:
Jadual yang terhasil menyediakan perwakilan ringkas data, dengan setiap pesanan sebagai lajur dan setiap item sebagai baris, memaparkan harga yang sepadan.
Atas ialah kandungan terperinci Bagaimana untuk Menukar Baris MySQL kepada Lajur Berdasarkan Berbilang Lajur?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!