Rumah >pangkalan data >tutorial mysql >Bagaimanakah CTE PostgreSQL Boleh Memasukkan Berbilang Baris Merentasi Berbilang Jadual dengan Cekap?

Bagaimanakah CTE PostgreSQL Boleh Memasukkan Berbilang Baris Merentasi Berbilang Jadual dengan Cekap?

Linda Hamilton
Linda Hamiltonasal
2025-01-01 13:23:12850semak imbas

How Can PostgreSQL CTEs Efficiently Insert Multiple Rows Across Multiple Tables?

Memasukkan Berbilang Baris dengan CTE PostgreSQL

Andaikan anda mempunyai pangkalan data hubungan dengan tiga jadual: jadual1, jadual2 dan jadual3. Jadual jadual1 menyimpan maklumat pengguna umum, manakala jadual jadual2 dan jadual3 mengandungi data tambahan seperti kata laluan dan alamat. Semasa anda menambah pengguna baharu dalam jadual1, anda mahu memasukkan ID pengguna dan data unik lain secara serentak ke dalam jadual anak table2 dan table3.

Postgres 9.3 CTE pengubahsuai data menyediakan penyelesaian kepada senario ini. CTE membolehkan anda merantai berbilang operasi INSERT dengan cekap.

Berikut ialah cara menggunakan CTE pengubahsuai data untuk menyelesaikan tugas anda:

WITH ins1 AS (
    INSERT INTO table1 (username, name, surname)
    VALUES ('johnee', 'john', 'smith')
    RETURNING user_id
),
ins2 AS (
    INSERT INTO table2 (user_id, password)
    SELECT ins1.user_id, 'secret'
    FROM ins1
    -- Nothing to return here
)
INSERT INTO table3 (user_id, address, city, phone)
SELECT ins1.user_id, ..., ...
FROM ins1
RETURNING user_id;

Pecahan CTE:

  • ins1 CTE: Memasukkan baris baharu ke dalam jadual1 dan mengembalikan user_id yang baru dibuat.
  • ins2 CTE: Menggunakan user_id daripada ins1 untuk memasukkan data ke dalam jadual2. Memandangkan tidak ada keperluan untuk mengembalikan nilai, nilai itu ditinggalkan.
  • MASUKKAN Akhir: Sisipkan data ke dalam jadual3 menggunakan user_id daripada ins1 dan lajur tambahan. Anda boleh menentukan lajur dan nilai yang dikehendaki mengikut keperluan. Klausa RETURNING pilihan membolehkan anda mendapatkan semula user_id yang baru dibuat daripada jadual3.

Amalan Terbaik:

  • Sentiasa sertakan senarai definisi lajur dalam anda INSERT pernyataan untuk memastikan konsistensi dengan struktur jadual anda.
  • Jika lajur harus menerima nilai lalai, tinggalkan sahaja dalam pernyataan INSERT; Postgres akan memasukkan lalai secara automatik.
  • CTE terakhir boleh secara pilihan mengembalikan nilai, yang mungkin berguna untuk pemprosesan selanjutnya atau untuk mendapatkan ID yang baru dibuat.

Atas ialah kandungan terperinci Bagaimanakah CTE PostgreSQL Boleh Memasukkan Berbilang Baris Merentasi Berbilang Jadual dengan Cekap?. 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