Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mengubah Data dengan Cekap dalam SQL Menggunakan Teknik SQL Dinamik?
Artikel ini membincangkan cara menggunakan teknologi SQL dinamik untuk menukar data jadual kepada format jadual pangsi, memfokuskan pada meningkatkan kecekapan dan fleksibiliti penukaran data.
Pertanyaan berikut menggunakan penyataan CASE dan GROUP BY untuk melaksanakan pangsi data:
<code class="language-sql">SELECT bar, MAX(CASE WHEN abc."row" = 1 THEN feh ELSE NULL END) AS "val1", MAX(CASE WHEN abc."row" = 2 THEN feh ELSE NULL END) AS "val2", MAX(CASE WHEN abc."row" = 3 THEN feh ELSE NULL END) AS "val3" FROM ( SELECT bar, feh, row_number() OVER (partition by bar) as row FROM "Foo" ) abc GROUP BY bar </code>
Kaedah ini berkesan untuk memutar data, tetapi kurang cekap dan kurang fleksibel apabila berurusan dengan set data yang besar.
yang disediakan oleh modul tablefunc
crosstab()
PostgreSQL boleh menyediakan penyelesaian yang lebih cekap dan dinamik.
Pasang modul tablefunc
Sebelum menggunakan crosstab()
, anda perlu memastikan bahawa modul tablefunc
telah dipasang ke dalam pangkalan data PostgreSQL. Anda hanya perlu melaksanakan arahan berikut sekali bagi setiap pangkalan data:
<code class="language-sql">CREATE EXTENSION tablefunc;</code>
Pelaksanaan Crosstab
Pertanyaan crosstab
berikut boleh digunakan untuk berputar:
<code class="language-sql">SELECT * FROM crosstab( 'SELECT bar, 1 AS cat, feh FROM tbl_org ORDER BY bar, feh') AS ct (bar text, val1 int, val2 int, val3 int); -- 可根据需要增加列</code>
Arahan:
tbl_org
ialah jadual input. crosstab()
memilih bar
, kategori tiruan cat
dan feh
. Lajur cat
hanya berfungsi sebagai pemegang tempat dan akan diabaikan. ORDER BY
memastikan bahawa nilai berada dalam susunan yang betul. Pertanyaan ini akan mengembalikan data dalam format jadual pangsi yang dikehendaki.
Untuk mencapai aplikasi yang lebih dinamik, kami boleh menggunakan fungsi tetingkap untuk mensintesis lajur kategori:
<code class="language-sql">SELECT * FROM crosstab( $$ SELECT bar, val, feh FROM ( SELECT *, 'val' || row_number() OVER (PARTITION BY bar ORDER BY feh) AS val FROM tbl_org ) x ORDER BY 1, 2 $$ , $$VALUES ('val1'), ('val2'), ('val3')$$ -- 可根据需要增加列 ) AS ct (bar text, val1 int, val2 int, val3 int); -- 可根据需要增加列</code>
Pertanyaan ini mencipta lajur kategori secara dinamik berdasarkan nilai dalam jadual.
Secara keseluruhannya, fungsi crosstab()
menyediakan penyelesaian yang lebih cekap dan fleksibel untuk berputar dalam SQL, memudahkan pertanyaan dan membenarkan penyesuaian fleksibel mengikut keperluan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengubah Data dengan Cekap dalam SQL Menggunakan Teknik SQL Dinamik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!