更新查询标识符

时间:2013-06-03 21:07:13

标签: sql oracle

UPDATE Table1 a
SET a.Col2 = (
    SELECT SubStr(Trim(b.Col2),-10,10)
    FROM Table2 b
    WHERE (InStr(SubStr(Trim(b.Col2),-5,5),'/')=1 
        AND InStr(SubStr(Trim(b.Col2),1,(Length(Trim(b.Col2))-10)),'/')=0 
        AND SubStr(b.Col1,1,2)='01'
        AND b.Col3 != 000103))
WHERE SubStr(b.Col1,-8,8)=SubStr(a.Col1,1,8)
    AND a.Col3 = 1;

命令行错误:9列:14 错误报告: SQL错误:ORA-00904:“B”。“Col1”:标识符无效 00904. 00000 - “%s:无效标识符”

第9行是WHERE SubStr(b.Col1,-8,8)=SubStr(a.Col1,1,8)

1 个答案:

答案 0 :(得分:1)

您可以尝试MERGE

MERGE INTO Table1 a
USING (
    SELECT *
    FROM Table2 b
    WHERE (InStr(SubStr(Trim(b.Col2),-5,5),'/')=1 
        AND InStr(SubStr(Trim(b.Col2),1,(Length(Trim(b.Col2))-10)),'/')=0 
        AND SubStr(b.Col1,1,2)='01'
        AND b.Col3 != 000103)
) c ON (SubStr(c.Col1,-8,8)=SubStr(a.Col1,1,8))
WHEN MATCHED THEN
    UPDATE SET a.Col2 = SubStr(Trim(c.Col2),-10,10)
        WHERE a.Col3 = 1;