Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Oracle SQL-Update basierend auf einer Unterabfrage zwischen zwei Tabellen

Es gibt zwei Möglichkeiten, das zu tun, was Sie versuchen

Eines ist ein Multi-column Correlated Update

UPDATE PRODUCTION a
SET (name, count) = (
  SELECT name, count
  FROM STAGING b
  WHERE a.ID = b.ID);

DEMO

Sie können zusammenführen verwenden

MERGE INTO PRODUCTION a
USING ( select id, name, count 
          from STAGING ) b
ON ( a.id = b.id )
WHEN MATCHED THEN 
UPDATE SET  a.name = b.name,
            a.count = b.count

DEMO