Oracle
 sql >> Base de données >  >> RDS >> Oracle

Requête SQL pour trouver les lignes manquantes entre deux tables liées

SELECT A.ABC_ID, A.VAL FROM A WHERE NOT EXISTS 
   (SELECT * FROM B WHERE B.ABC_ID = A.ABC_ID AND B.VAL = A.VAL)

ou

SELECT A.ABC_ID, A.VAL FROM A WHERE VAL NOT IN 
    (SELECT VAL FROM B WHERE B.ABC_ID = A.ABC_ID)

ou

SELECT A.ABC_ID, A.VAL LEFT OUTER JOIN B 
    ON A.ABC_ID = B.ABC_ID AND A.VAL = B.VAL FROM A WHERE B.VAL IS NULL

Veuillez noter que ces requêtes ne nécessitent pas du tout que ABC_ID soit dans la table B. Je pense que cela fait ce que vous voulez.