Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menukar Baris MySQL kepada Lajur Berdasarkan Berbilang Lajur?

Bagaimana untuk Menukar Baris MySQL kepada Lajur Berdasarkan Berbilang Lajur?

Barbara Streisand
Barbara Streisandasal
2025-01-03 07:27:40202semak imbas

How to Convert MySQL Rows to Columns Based on Multiple Columns?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn