Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Melakukan Pivoting Dinamik dalam MySQL Menggunakan Penyata Disediakan?
Pangsi Dinamik dalam MySQL
Dalam MySQL, jadual selalunya mengandungi data dalam format yang dinormalkan, memerlukan pertanyaan kompleks untuk mendapatkan data dalam lebih ramai pengguna -format mesra. Satu transformasi sedemikian ialah berputar, di mana lajur ditukar kepada baris.
Pertimbangkan jadual seperti "Bahagian", yang mengaitkan bahagian produk (part_id) dengan jenis produk (part_type) dan ID produk (product_id). Kami ingin menukar jadual ini untuk membuat jadual baharu yang menunjukkan ID bahagian setiap produk untuk jenis bahagian yang berbeza.
MySQL tidak mempunyai fungsi PIVOT khusus, jadi kami perlu menggunakan teknik alternatif. Satu penyelesaian melibatkan penggunaan fungsi agregat dan pernyataan CASE. Untuk pangsi dinamik, kami boleh memanfaatkan pernyataan yang disediakan.
Pertanyaan Pangsi Dinamik
Pertanyaan berikut menggunakan SQL dinamik untuk memutar jadual "Bahagian":
SET @sql = NULL; SELECT GROUP_CONCAT(DISTINCT CONCAT( 'max(case when part_type = ''', part_type, ''' then part_id end) AS part_', part_type, '_id' ) ) INTO @sql FROM parts; SET @sql = CONCAT('SELECT product_id, ', @sql, ' FROM parts GROUP BY product_id'); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt;
Pertanyaan ini secara dinamik menjana pernyataan SQL berdasarkan jenis bahagian berbeza yang terdapat dalam jadual dan melaksanakannya menggunakan pernyataan yang disediakan untuk prestasi yang lebih baik.
Contoh Hasil
Jadual yang terhasil akan mempunyai format berikut:
product_id part_A_id part_B_id ---------------------------------------- 1 1 2 2 3 4 3 5 6
Pertanyaan Pangsi Statik
Untuk bilangan jenis bahagian yang terhad, statik pertanyaan pangsi boleh digunakan:
select product_id, max(case when part_type ='A' then part_id end) as Part_A_Id, max(case when part_type ='B' then part_id end) as Part_B_Id from parts group by product_id
Pertanyaan ini secara manual menentukan jenis bahagian dan menjana jadual pangsi.
Atas ialah kandungan terperinci Bagaimana untuk Melakukan Pivoting Dinamik dalam MySQL Menggunakan Penyata Disediakan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!