Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mengubah Baris MySQL secara Dinamik ke dalam Lajur?

Bagaimana untuk Mengubah Baris MySQL secara Dinamik ke dalam Lajur?

Mary-Kate Olsen
Mary-Kate Olsenasal
2025-01-25 13:12:16825semak imbas

How to Dynamically Pivot MySQL Rows into Columns?

operasi baris ke lajur dinamik MySQL

Soalan:

Dapatkan semula data daripada berbilang jadual dan formatkannya menjadi jadual pangsi dengan pengepala lajur dinamik, walaupun bilangan lajur yang tepat tidak diketahui terlebih dahulu.

Pertanyaan asal:

<code class="language-sql">SELECT partners.name, products.name, COUNT(*) 
FROM sales
JOIN products ON sales.products_id = products.id
JOIN partners ON sales.partners_id = partners.id
GROUP BY sales.partners_id, sales.products_id
LIMIT 0, 30</code>

Penyelesaian menggunakan pernyataan KES:

MySQL tidak mempunyai fungsi PIVOT, jadi anda perlu menggunakan fungsi agregat dengan pernyataan CASE:

<code class="language-sql">select pt.partner_name,
  count(case when pd.product_name = 'Product A' THEN 1 END) as ProductA,
  count(case when pd.product_name = 'Product B' THEN 1 END) as ProductB,
  count(case when pd.product_name = 'Product C' THEN 1 END) as ProductC,
  count(case when pd.product_name = 'Product D' THEN 1 END) as ProductD,
  count(case when pd.product_name = 'Product E' THEN 1 END) as ProductE
from partners pt
left join sales s
  on pt.part_id = s.partner_id
left join products pd
  on s.product_id = pd.prod_id
group by pt.partner_name</code>

Jadual pangsi dinamik menggunakan pernyataan yang disediakan:

Untuk mengendalikan pengepala lajur dinamik, anda boleh menggunakan pernyataan yang disediakan:

<code class="language-sql">SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'count(case when Product_Name = ''',
      Product_Name,
      ''' then 1 end) AS ',
      replace(Product_Name, ' ', '')
    )
  ) INTO @sql
from products;

SET @sql = CONCAT('SELECT pt.partner_name, ', @sql, ' from partners pt
left join sales s
  on pt.part_id = s.partner_id
left join products pd
  on s.product_id = pd.prod_id
group by pt.partner_name');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;</code>

Atas ialah kandungan terperinci Bagaimana untuk Mengubah Baris MySQL secara Dinamik ke dalam 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