0

我究竟如何让它发挥作用?我正在尽力形成一个查询,该查询采用从第一个查询生成的主键,然后将它们与静态第二个值 (33) 一起插入到第二个表中。我显然收到了“用作表达式的子查询返回的不止一行”错误。我用谷歌搜索了我的眼球,无法弄清楚这个问题。也许有更好的方法来做我想做的事情。

如果这很重要,我正在使用 Postgresql 9.5。

 WITH x AS (INSERT INTO OPTIONS (manufacturer_id, category, name, description)
VALUES (
    UNNEST(ARRAY['10', '22', '33']),
    'ExtColor',
    UNNEST(ARRAY['EC', 'IC', 'IO']),
    UNNEST(ARRAY['a', 'b', 'c'])
)
RETURNING option_id)
INSERT INTO opt_car_data (car_id, option_id) VALUES ((SELECT option_id FROM x), 33);
4

1 回答 1

1
WITH x AS (
    INSERT INTO options (manufacturer_id, category, name, description)
    VALUES (
        UNNEST(ARRAY['10', '22', '33']),
        'ExtColor',
        UNNEST(ARRAY['EC', 'IC', 'IO']),
        UNNEST(ARRAY['a', 'b', 'c'])
    )
    RETURNING option_id
)
INSERT INTO opt_car_data (car_id, option_id) 
SELECT option_id, 33 
FROM x;
于 2016-10-31T04:16:29.693 回答