【问题标题】:Unable to update multiple columns with 'with' clause无法使用“with”子句更新多个列
【发布时间】:2017-10-17 10:31:43
【问题描述】:

我正在使用以下查询(它适用于一列,即 base_price)但是当我尝试更新多个列时,我得到 ORA-01767: UPDATE ... SET 表达式必须是子查询。

UPDATE quote_item qi
SET (qi.base_price,qi.base_cost)
  =
  ( WITH baseVersion AS
  (SELECT qi1.quote_oid, qi1.item_num, qi1.sub_item_num as sub_item_num,  q1.quote_num,  qi1.base_price,  qi1.base_cost
  FROM quote q1,
    quote_item qi1
  WHERE q1.oid         = qi1.quote_oid
  AND q1.quote_type_oid=4
  AND q1.version_num = 0
  )
SELECT bv.base_price,bv.base_cost
FROM baseVersion bv,
  quote revQuote
WHERE revQuote.oid      = qi.quote_oid
AND revQuote.quote_num  = bv.quote_num
AND qi.item_num          =bv.item_num
AND qi.sub_item_num      =bv.sub_item_num
AND revQuote.version_num >0 and revQuote.quote_type_oid=4
  )
  where qi.quote_type_oid=4;

环顾四周后,我找到了一个解决方案,可以通过从 with 子句中再次选择来完成,但我无法在查询 reference 中实现它。

有人知道怎么做吗?

【问题讨论】:

    标签: oracle


    【解决方案1】:

    您不能从同一个子查询中更新多个列。您可以为另一列重用子查询(我不建议这样做,因为查询将执行两次),或者您可以使用 oracle 的 MERGE 。它看起来像这样(调整它):

    MERGE INTO quote_item qi
    USING ( Your subquery goes here ) t
     ON(t.oid      = qi.quote_oid
        AND qi.item_num          =t.item_num
        AND qi.sub_item_num      =t.sub_item_num)
    WHEN MATCHED THEN UPDATE 
         SET qi.col1 = ..,
             qi.col2 = ..
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-04-21
      • 2023-01-11
      • 2023-02-23
      • 2021-11-06
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多