นี่คือตัวอย่างเล็กน้อยของปัญหาจริงของฉัน:
create table t(id serial primary key, rnd double precision);แน่นอนคุณสามารถส่งคืนคอลัมน์ที่แทรกด้วยreturningประโยค:
with w as (insert into t(rnd) values(random()) returning *)
insert into t(rnd) select random() from w returning *;
/*
| ID |            RND |
|----|----------------|
|  9 | 0.203221440315 |
*/คุณสามารถคืนค่าตัวอักษร:
with w as (insert into t(rnd) values(random()) returning *)
insert into t(rnd) select random() from w returning *, 1.0 dummy;
/*
| ID |            RND | DUMMY |
|----|----------------|-------|
| 11 | 0.594980469905 |     1 |
*/แต่คุณไม่สามารถคืนคอลัมน์ต้นฉบับได้:
with w as (insert into t(rnd) values(random()) returning *)
insert into t(rnd) select random() from w returning *, w.rnd;
/*
ERROR: missing FROM-clause entry for table "w": with w as (insert into t(rnd) values(random()) returning *) insert into t(rnd) select random() from w returning *, w.rnd
*/มีวิธีใดบ้างที่ฉันจะw.rndออกจากreturningประโยคสุดท้าย?
db <> ซอที่นี่
UPDATEในคำตอบที่เกี่ยวข้องใน SOแต่ไม่สามารถทำงานINSERTได้