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
Mary-Kate Olsenasal
2025-01-20 22:46:12785semak imbas

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:

<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.

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:

<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.
  • 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:

<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.

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:
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