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

Tiefes Oracle SQL-Update

MERGE ist ein guter Weg.

Es gibt eine Tasche:items=Item1, Item2

Es gibt eine BagInDB:bag_id =1items=Item1,Item3

Also müssen wir Item1 aktualisieren, Item2 hinzufügen und Item3 löschen

1. Schritt (beitreten):

select * from bag full outer join (select * from bagInDB where bag_id = 1)

es wird dir geben

bag_itemName bagInDb_itemName
------------ ----------------
Item1        Item1
Item2        null
null         Item3

2. Schritt (zusammenführen)

merge into baginDB b
using(query above) q on b.bag_id = 1 and b.itemName = q.bagInDb_itemName
when matched then
delete where q.bag_itemName is null
<rest of the conditions>