Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mengubah Jadual SQL dengan Lajur Dijana Secara Dinamik?

Bagaimana untuk Mengubah Jadual SQL dengan Lajur Dijana Secara Dinamik?

Barbara Streisand
Barbara Streisandasal
2025-01-05 05:03:41531semak imbas

How to Transpose a SQL Table with Dynamically Generated Columns?

Transpose SQL Table: Mencapai Transformasi Data Fleksibel

Transpose operasi dalam SQL melibatkan penukaran baris kepada lajur dan sebaliknya. Dalam konteks ini, mari kita atasi masalah pemindahan jadual dengan nama medan yang ditentukan pengguna untuk data khusus pengguna.

Masalah:

Diberikan jadual dengan pengguna- nama medan yang ditentukan dan nilai yang sepadan, matlamatnya adalah untuk mengubahnya ke dalam format yang mana setiap data pengguna dibentangkan dalam satu baris, dengan lajur nama yang mewakili nama medan.

Contoh:

Jadual Input:

Id UserId FieldName FieldValue
1 100 Username John Doe
2 100 Password pass123!
3 102 Username Jane
4 102 Password $ecret
5 102 Email Address [email protected]

Output yang Diingini:

UserId Username Password Email Address
100 John Doe pass123! NULL
102 Jane $ecret [email protected]

Penyelesaian dalam MySQL (Tanpa ANSI Sintaks):

Memandangkan MySQL tidak menyokong sintaks ANSI PIVOT/UNPIVOT, kami boleh menggunakan pendekatan pengagregatan bersyarat:

SELECT t.userid,
       MAX(CASE WHEN t.fieldname = 'Username' THEN t.fieldvalue ELSE NULL END) AS Username,
       MAX(CASE WHEN t.fieldname = 'Password' THEN t.fieldvalue ELSE NULL END) AS Password,
       MAX(CASE WHEN t.fieldname = 'Email Address' THEN t.fieldvalue ELSE NULL END) AS Email
FROM TABLE t
GROUP BY t.userid

Pendekatan ini berulang pada setiap baris dan menggunakan pernyataan CASE untuk memberikan nilai kepada lajur keluaran yang dikehendaki berdasarkan nama medan. Ia kemudiannya mengagregatkan keputusan untuk setiap userId.

Penyelesaian Dinamik menggunakan Penyata Disediakan:

Untuk menjadikan penyelesaian lebih serba boleh, kami boleh menggunakan sintaks Penyata Disediakan MySQL, yang membolehkan kami untuk menentukan medan secara dinamik:

SET @query = "SELECT userid, ";
SET @enum_query = "";
SELECT CONCAT(@enum_query, "MAX(CASE WHEN fieldname = '", fieldname, "' THEN fieldvalue ELSE NULL END) AS ", fieldname,", ")
INTO @enum_query
FROM (
    SELECT DISTINCT fieldname
    FROM TABLE
) AS subquery;
SET @enum_query = SUBSTRING(@enum_query, 1, LENGTH(@enum_query) - 2);
SET @query = CONCAT(@query, @enum_query, " FROM TABLE GROUP BY userid;");
PREPARE stmt FROM @query;
EXECUTE stmt;

Pendekatan ini mewujudkan pertanyaan dinamik yang merangkumi semua nama medan yang diingini sebagai lajur dalam output.

Atas ialah kandungan terperinci Bagaimana untuk Mengubah Jadual SQL dengan Lajur Dijana Secara Dinamik?. 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