Declaración de actualización con unión interna en Oracle

Resuelto user169743 asked hace 14 años • 16 respuestas

Tengo una consulta que funciona bien en MySQL, pero cuando la ejecuto en Oracle me sale el siguiente error:

Error de SQL: ORA-00933: el comando SQL no finalizó correctamente
00933. 00000 - "El comando SQL no finalizó correctamente"

La consulta es:

UPDATE table1
INNER JOIN table2 ON table1.value = table2.DESC
SET table1.value = table2.CODE
WHERE table1.UPDATETYPE='blah';
user169743 avatar Mar 15 '10 18:03 user169743
Aceptado

Esa sintaxis no es válida en Oracle. Puedes hacerlo:

UPDATE table1 SET table1.value = (SELECT table2.CODE
                                  FROM table2 
                                  WHERE table1.value = table2.DESC)
WHERE table1.UPDATETYPE='blah'
AND EXISTS (SELECT table2.CODE
            FROM table2 
            WHERE table1.value = table2.DESC);

O tal vez puedas hacer esto:

UPDATE 
(SELECT table1.value as OLD, table2.CODE as NEW
 FROM table1
 INNER JOIN table2
 ON table1.value = table2.DESC
 WHERE table1.UPDATETYPE='blah'
) t
SET t.OLD = t.NEW

Depende de si Oracle considera que la vista en línea es actualizable ( el hecho de que sea actualizable para la segunda declaración depende de algunas reglas enumeradas aquí ).

Tony Andrews avatar Mar 15 '2010 11:03 Tony Andrews

Utilizar esta:

MERGE
INTO    table1 trg
USING   (
        SELECT  t1.rowid AS rid, t2.code
        FROM    table1 t1
        JOIN    table2 t2
        ON      table1.value = table2.DESC
        WHERE   table1.UPDATETYPE='blah'
        ) src
ON      (trg.rowid = src.rid)
WHEN MATCHED THEN UPDATE
    SET trg.value = code;
Quassnoi avatar Mar 15 '2010 11:03 Quassnoi

MERGEcon WHEREcláusula:

MERGE into table1
USING table2
ON (table1.id = table2.id)
WHEN MATCHED THEN UPDATE SET table1.startdate = table2.start_date
WHERE table1.startdate > table2.start_date;

Necesita la WHEREcláusula porque las columnas a las que se hace referencia en la ONcláusula no se pueden actualizar.

Roland avatar May 07 '2015 14:05 Roland