Rumah > pangkalan data > tutorial mysql > Bagaimanakah CTE PostgreSQL dan INSERT...RETURNING Boleh Memasukkan Data dengan Cekap ke dalam Jadual Ibu Bapa dan Anak?

Bagaimanakah CTE PostgreSQL dan INSERT...RETURNING Boleh Memasukkan Data dengan Cekap ke dalam Jadual Ibu Bapa dan Anak?

Mary-Kate Olsen
Lepaskan: 2024-12-30 11:26:11
asal
921 orang telah melayarinya

How Can PostgreSQL CTEs and INSERT...RETURNING Efficiently Insert Data into Parent and Child Tables?

Memasukkan Berbilang Nilai ke dalam Jadual Anak Menggunakan INSERT PostgreSQL...RETURNING dan CTEs

Untuk memasukkan user_id yang baru diekstrak daripada jadual induk jadual1 ke dalam jadual anak table2 dan table3, PostgreSQL menyediakan penyelesaian yang elegan menggunakan pengubahsuaian data Ungkapan Jadual Biasa (CTE).

Menggunakan CTE, kami boleh merantai beberapa pernyataan INSERT untuk melaksanakan berbilang operasi dalam satu transaksi:

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
   )
INSERT INTO table3 (user_id, adress, city, phone)
SELECT ins1.user_id, ...
FROM ins1
RETURNING user_id;
Salin selepas log masuk

Kod ini mengikut proses langkah demi langkah :

  1. ins1: Sisipkan baris baharu ke dalam jadual1 dan mendapatkan semula user_id yang baru dijana menggunakan RETURNING. Langkah ini mewujudkan sambungan antara jadual kanak-kanak.
  2. ins2: Memasukkan user_id daripada ins1 ke dalam jadual2 bersama-sama dengan kata laluan.
  3. Memasukkan user_id daripada ins1 ke dalam jadual3 dengan data tambahan seperti alamat, bandar dan telefon.

Kunci Mata:

  • Adalah dinasihatkan untuk menyediakan senarai definisi lajur untuk INSERTs bagi memastikan integriti data.
  • Nilai lalai dimasukkan secara automatik, jadi lajur dengan nilai lalai boleh ditinggalkan dalam pernyataan INSERT.
  • Klausa RETURNING terakhir dalam pernyataan INSERT ketiga mengembalikan user_id daripada table3, walaupun ia lazimnya sama dengan user_id daripada table1.
  • CTE yang mengubah suai data membenarkan rantaian berbilang INSERT dan operasi manipulasi data lain ke dalam satu transaksi.

Atas ialah kandungan terperinci Bagaimanakah CTE PostgreSQL dan INSERT...RETURNING Boleh Memasukkan Data dengan Cekap ke dalam Jadual Ibu Bapa dan Anak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan