Tukar nilai baris dinamik kepada nama lajur menggunakan MySQL
Dalam jadual lama dengan struktur tetap, mendapatkan data dalam format pangsi boleh menjadi satu cabaran. MySQL tidak mempunyai fungsi pangsi asli dan memerlukan penggunaan pernyataan yang disediakan untuk menyelesaikan masalah ini.
Pertimbangkan jadual warisan berikut:
<code>id name value ------------------------------ 0 timezone Europe/London 0 language en 0 country 45 0 something x 1 timezone Europe/Paris 1 language fr 1 country 46</code>
Output yang diingini, menggunakan nilai baris dinamik sebagai nama lajur:
<code>id timezone language country something --------------------------------------------------- 0 Europe/London en 45 x 1 Europe/Paris fr 46</code>
Tidak seperti RDBMS lain, MySQL memerlukan kaedah tidak langsung. Membina pernyataan yang disediakan adalah pendekatan yang diutamakan.
<code class="language-sql">SELECT CONCAT( 'SELECT `table`.id', GROUP_CONCAT(' , `t_', REPLACE(name, '`', '``'), '`.value AS `', REPLACE(name, '`', '``'), '`' SEPARATOR ''), ' FROM `table` ', GROUP_CONCAT(' LEFT JOIN `table` AS `t_', REPLACE(name, '`', '``'), '` ON `table`.id = `t_', REPLACE(name, '`', '``'), '`.id AND `t_', REPLACE(name, '`', '``'), '`.name = ', QUOTE(name) SEPARATOR ''), ' GROUP BY `table`.id' ) INTO @qry FROM (SELECT DISTINCT name FROM `table`) t; PREPARE stmt FROM @qry; EXECUTE stmt;</code>
Pertanyaan ini menggunakan GROUP_CONCAT()
untuk membina pernyataan SQL dinamik untuk menyambungkan JOIN dan alias lajur yang diperlukan. Penyata SQL yang dihasilkan kemudiannya disediakan dan dilaksanakan.
Pendekatan ini membenarkan penggunaan nilai baris unik sebagai nama lajur berubah-ubah tanpa memerlukan subpilihan keras atau pernyataan CASE. Walaupun ia mungkin memerlukan lebih banyak persediaan, ia menyediakan penyelesaian yang lebih fleksibel dan cekap untuk memutar data dalam MySQL.
Atas ialah kandungan terperinci Bagaimana untuk Mengubah Nilai Baris Dinamik ke dalam Nama Lajur dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!