加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSql INSERT FROM SELECT RETURNING ID

发布时间:2020-12-13 16:42:31 所属栏目:百科 来源:网络整理
导读:在PostgreSql 9.2.4中有两个表:user(id,login,password,name)和dealer(id,user_id)。 而且我想插入两个表,返回创建的经销商的ID。 目前我正在做两个查询: WITH rows AS ( INSERT INTO "user" (login,password,name) VALUES ('dealer1','jygbjybk','De
在PostgreSql 9.2.4中有两个表:user(id,login,password,name)和dealer(id,user_id)。

而且我想插入两个表,返回创建的经销商的ID。

目前我正在做两个查询:

WITH rows AS (
    INSERT INTO "user"
        (login,password,name)
    VALUES
        ('dealer1','jygbjybk','Dealer 1')
    RETURNING id
)
INSERT INTO dealer (user_id)
    SELECT id
    FROM rows;
SELECT currval('dealer_id_seq');

但是可以使用RETURNING语句使用单个INSERT查询实现吗?

你只需要添加一个RETURNING id到你的INSERT … SELECT:
WITH rows AS (...)
INSERT INTO dealer (user_id)
    SELECT id
    FROM rows
    RETURNING id;

演示:http://sqlfiddle.com/#!12/75008/1

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读