为什么公用表表达式不适用于INSERT SELECT [英] Why Common table expression does not work with INSERT SELECT

查看:15
本文介绍了为什么公用表表达式不适用于INSERT SELECT的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正尝试在INSERT中使用公用表表达式。 当我这样做时:

with A as (select col1,col2 from table1) select * from A

它有效 但当我这样做的时候:

with A as (select col1,col2 from table1) 
insert into table2 (col1,col2) (select col1,col2 from A)

我得到:

found "INSERT" (at char XXXXX) expecting `SELECT' or `'(''

推荐答案

您的查询应该适用于大多数数据库。然而,Oracle和更早版本的Postgres将CTE放在select旁边。因此,如果您使用的是Oracle、更早版本的Postgres或Postgres派生数据库:

insert into table2 (col1, col2)
    with A as (select col1, col2 from table1) 
    select col1, col2 from A;

此外,select查询前后不需要括号。它不是子查询。

这篇关于为什么公用表表达式不适用于INSERT SELECT的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆