Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Mengubah Data dengan Cekap dalam SQL Menggunakan Teknik SQL Dinamik?

Bagaimanakah Saya Boleh Mengubah Data dengan Cekap dalam SQL Menggunakan Teknik SQL Dinamik?

Mary-Kate Olsen
Lepaskan: 2025-01-20 22:46:12
asal
837 orang telah melayarinya

How Can I Efficiently Pivot Data in SQL Using Dynamic SQL Techniques?

Gunakan SQL dinamik untuk melaksanakan pangsi data SQL dengan cekap

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 Awal

Pertanyaan berikut menggunakan penyataan CASE dan GROUP BY untuk melaksanakan pangsi data:

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 
Salin selepas log masuk

Kaedah ini berkesan untuk memutar data, tetapi kurang cekap dan kurang fleksibel apabila berurusan dengan set data yang besar.

Penyelesaian yang dipertingkat menggunakan fungsi Crosstab

Fungsi

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:

CREATE EXTENSION tablefunc;
Salin selepas log masuk

Pelaksanaan Crosstab

Pertanyaan crosstab berikut boleh digunakan untuk berputar:

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);  -- 可根据需要增加列
Salin selepas log masuk

Arahan:

  • tbl_org ialah jadual input.
  • Subkueri dalam
  • crosstab() memilih bar, kategori tiruan cat dan feh. Lajur cat hanya berfungsi sebagai pemegang tempat dan akan diabaikan.
  • Klausa
  • ORDER BY memastikan bahawa nilai berada dalam susunan yang betul.

Pertanyaan ini akan mengembalikan data dalam format jadual pangsi yang dikehendaki.

Tab Silang Dinamik

Untuk mencapai aplikasi yang lebih dinamik, kami boleh menggunakan fungsi tetingkap untuk mensintesis lajur kategori:

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);  -- 可根据需要增加列
Salin selepas log masuk

Pertanyaan ini mencipta lajur kategori secara dinamik berdasarkan nilai dalam jadual.

Kesimpulan

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!

Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan