View Full Version : SQL: selezionare campi NON presenti in un'altra tabella...
Ho due tabelle, ma di una vorrei selezionare i campi la cui chiave (composta da 4 campi) non è presente in un'altra tabella
Parlo di SQL x database ORACLE.
Dunque:
TAB1
keyA
keyB
KeyC
KeyD
TAB2
kA
kB
KC
kD
Nella Tab2 ho presenti molti valori che nella TAB1 sono stati eliminati, quindi vorrei selezionare quali di quelli nella TAB2 non esistono in TAB1.
Spero di essermi spiegato.
Stò provando con :
SELECT .... FROM tab1,tab2 WHERE keya<> ka AND keyb<>kb and Keyc<>kc and Keyd<>kd
ma non mi sembra avere un esito positivo (è un bel pò che aspetto ma non mi dà niente...)
GRAZIE.
monkey72
22-04-2003, 13:38
imho l'uso dell'and non è corretto... affinchè due record siano diversi basta che lo sia almeno un campo, non tutti quindi in questa:
Originally posted by "dani&l"
SELECT .... FROM tab1,tab2 WHERE keya<> ka AND keyb<>kb and Keyc<>kc and Keyd<>kd
.
metterei OR al posto di AND e poi riferisci le tabelle a cui appartengono i campi, es. tab1.keya, tab2.ka... anche se forse questo è necessario solo se le tabelle hanno campi con lo stesso nome... :rolleyes:
Secondo me è sbagliato eseguire una SQL di questo tipo:
SELECT .... FROM tab1,tab2 WHERE keya<> ka AND keyb<>kb and Keyc<>kc and Keyd<>kd
perchè usando un from di questo tipo " ... FROM tab1,tab2 ..." vengono estratti per ogni record della tabella1, tutti i record della tabella2 (Una specie di prodotto cartesiano) ...
Se vuoi identificare esattamente i record della tabella2 non inclusi nella tabella1 devi creare un Join Quadruplo tra i vari campi che compongono la chiave.In questo modo è come avere un unico Join (Come se fosse un solo campo)
SQL Access:
SELECT DISTINCT Tabella1.A, Tabella1.B, Tabella1.C, Tabella1.D, Tabella2.A, Tabella2.B, Tabella2.C, Tabella2.D
FROM Tabella1 LEFT JOIN Tabella2 ON (Tabella1.A = Tabella2.A) AND (Tabella1.B = Tabella2.B) AND (Tabella1.C = Tabella2.C) AND (Tabella1.D = Tabella2.D)
WHERE Tabella2.A is null or Tabella2.B is null or Tabella2.C is null or Tabella2.D is null
SQL Oracle:
SELECT DISTINCT TABELLA1.A, TABELLA1.B, TABELLA1.C, TABELLA1.D, TABELLA2.A, TABELLA2.B, TABELLA2.C, TABELLA2.D FROM TABELLA1, TABELLA2 WHERE ( TABELLA2.A IS NULL OR TABELLA2.B IS NULL OR TABELLA2.C IS NULL OR TABELLA2.D IS NULL) And (TABELLA1.A = TABELLA2.A (+) AND TABELLA1.B = TABELLA2.B (+) AND TABELLA1.C = TABELLA2.C (+) AND TABELLA1.D = TABELLA2.D (+) )
Con questa SQL verranno estratti tutti i campi della tabella1 non inclusi nella tabella2.
E' un po' un casino ma dovrebbe funzionare ... prova!
Ciao! :)
Originally posted by "cisky"
...
SQL Oracle:
SELECT DISTINCT TABELLA1.A, TABELLA1.B, TABELLA1.C, TABELLA1.D, TABELLA2.A, TABELLA2.B, TABELLA2.C, TABELLA2.D FROM TABELLA1, TABELLA2 WHERE ( TABELLA2.A IS NULL OR TABELLA2.B IS NULL OR TABELLA2.C IS NULL OR TABELLA2.D IS NULL) And (TABELLA1.A = TABELLA2.A (+) AND TABELLA1.B = TABELLA2.B (+) AND TABELLA1.C = TABELLA2.C (+) AND TABELLA1.D = TABELLA2.D (+) )
Con questa SQL verranno estratti tutti i campi della tabella1 non inclusi nella tabella2.
E' un po' un casino ma dovrebbe funzionare ... prova!
Ciao! :)
Sembra FUNZIONARE!! Non è che mi spiegheresti cosa comportano quei "(+)" ?
Poi ti rompo ancora, volendoli eliminare con una DELETE, finchè si tratta di una tabella non ci sono problemi, ma con due tabelle come mi devo comportare ??
DELETE FROM TABELLA1,TABELLA2 WHERE ....(condizioni precedenti) ???
Non rischio di cancellare anche la TABELLA2 ??
Grazie.
Allora ... i (+) non sono nient'altro che la sintassi oracle per definire un outer JOIN (Left o Right JOIN in Acces) ... si può dire che il (+) indica la "direzione" del JOIN (A grandi linee)
Es:
Access: "... RIGHT JOIN Tabella2 ON Tabella1.ID = Tabella2.ID "
Diventa => ... WHERE (TABELLA1.ID (+) = TABELLA2.ID)
Access: "... LEFT JOIN Tabella2 ON Tabella1.ID = Tabella2.ID"
Diventa = > ... WHERE (TABELLA1.ID = TABELLA2.ID (+) )
Per quanto riguarda l'eliminazione dei dati da una delle 2 tabelle non ho mai provato ad eseguire in oracle una SQL di eliminazione con tabelle multiple.
Mi sembra che in access non è possibile eseguire una Query di eliminazione che rimuove i record di una tabella collegata ad altre tramite relazioni uno a molti.
... Mah, provo ad informarmi e ti faccio sapere!
Ciao ;)
Con Oracle purtroppo non sono molto ferrato :(
Ho provato a rovistare un po' in giro e sembra che non sia possibile in oracle eliminare dei record tramite una querycomposta da varie tabelle.
... Non sono certo ma è moooltooo provabile!
Soluzioni alternative al problema:
Se le tabelle in questione dispongono di un campo ID univoco (Cosa che dovrebbe sempre essere fatta!) basta che crei una query che identifica tutti gli ID della tabella in base ai dati che non corrispondono <... vedi mia SQL precedente ...> ed esegui una SQL di questo tipo :
DELETE * FROM tbl1 WHERE tbl1.ID IN (SELECT .... FROM ... WHERE ...)
Se ti può essere di aiuto qui trovi una breve guida alla sintassi Oracle:
http://www.archesis.it/white/oracle/sql_ora.htm
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.