2017-10-17 1 views
1

다음 쿼리 (하나의 열 즉 base_price에 대해 잘 작동 함)를 사용하고 있지만 둘 이상의 열을 업데이트하려고 할 때 ORA-01767 : UPDATE가 표시됩니다. SET 표현식은 하위 쿼리 여야합니다. 주변을 둘러 보는 일부 후'with'절을 사용하여 여러 열을 업데이트 할 수 없음

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; 

나는이 절과에서 다시 선택하여 수행 할 수있는 솔루션을 발견하지만 난 내 쿼리 reference에서 그것을 구현할 수 없습니다입니다.

누구든지이 작업을 수행하는 방법을 알고 있습니까?

답변

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 = .. 
관련 문제