PostgreSql INSERT FROM SELECT RETURNING ID

在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

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...