|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Bannato
Iscritto dal: Nov 2000
Città: mi
Messaggi: 18790
|
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. |
![]() |
![]() |
![]() |
#2 | |
Senior Member
Iscritto dal: Dec 2001
Messaggi: 1385
|
Re: SQL: selezionare campi NON presenti in un'altra tabella.
imho l'uso dell'and non è corretto... affinchè due record siano diversi basta che lo sia almeno un campo, non tutti quindi in questa:
Quote:
![]()
__________________
lui è il mio amore: "tesò domani ti regalo un guinzaglio lungo 100 km" ![]() |
|
![]() |
![]() |
![]() |
#3 | |
Member
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
|
Secondo me è sbagliato eseguire una SQL di questo tipo:
Quote:
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! ![]() |
|
![]() |
![]() |
![]() |
#4 | |
Bannato
Iscritto dal: Nov 2000
Città: mi
Messaggi: 18790
|
Quote:
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. |
|
![]() |
![]() |
![]() |
#5 |
Member
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
|
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 ![]() |
![]() |
![]() |
![]() |
#6 |
Member
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
|
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 |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 10:09.