简体   繁体   English

将 2 个 CTE 替换为 1 个

[英]Replace 2 CTEs to one

I have following code on postgresql:我在 postgresql 上有以下代码:

    WITH CTE1 AS
(
SELECT
               value_1
              ,position
              ,value_3
              ,value_4
              ,value_5
From tabl_1
WHERE position = 1 
)

WITH CTE2 AS
(
SELECT
               value_1
              ,position
              ,value_3
              ,value_4
              ,value_5
From tabl_1
WHERE position = 2 
)   

INSERT INTO tbl_2
SELECT
CTE1.value_2 = IP_1
CTE2.value_2 = IP_2

FROM table_3 er
                LEFT JOIN CTE1 ON CTE1.value_1 = er.value_1 AND CTE1.value_3 = er.value_3
                LEFT JOIN CTE2 ON CTE2.value_1 = er.value_1 AND CTE2.value_3 = er.value_3

I calculate value for IP_1, IP-2 in separate CTE, but I haven't idea how I can replace 2 CTE's on one?我在单独的 CTE 中计算 IP_1、IP-2 的值,但我不知道如何将 2 个 CTE 替换为一个? Or some other way.或者其他方式。

Copying your code, which seems to have a number of errors:复制你的代码,它似乎有很多错误:

  • no comma between the two columns being inserted;插入的两列之间没有逗号;
  • value_2 isn't in either of your CTEs. value_2 不在您的任何一个 CTE 中。

This can be refactored to remove all CTEs:这可以重构以删除所有 CTE:

INSERT INTO 
    tbl_2
SELECT
    t1.value_2 = IP_1
    t2.value_2 = IP_2
FROM 
    table_3 er
    LEFT JOIN tabl_1 t1 ON t1.value_1 = er.value_1 AND t1.value_3 = er.value_3 AND t1.position = 1
    LEFT JOIN tabl_1 t2 ON t2.value_1 = er.value_1 AND t2.value_3 = er.value_3 AND t2.position = 2

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM