


Bagaimana untuk Menukar Baris MySQL kepada Lajur Berdasarkan Berbilang Lajur?
Jan 03, 2025 am 07:27 AMPertanyaan 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!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Kurangkan penggunaan memori MySQL di Docker

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table?

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama

Apa itu SQLite? Gambaran Keseluruhan Komprehensif

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin)

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah

Bagaimanakah saya menjamin MySQL terhadap kelemahan biasa (suntikan SQL, serangan kekerasan)?

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL?
