Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-04-2003, 09:54   #1
dani&l
Bannato
 
L'Avatar di dani&l
 
Iscritto dal: Nov 2000
Città: mi
Messaggi: 18791
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.
dani&l è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2003, 13:38   #2
monkey72
Senior Member
 
L'Avatar di monkey72
 
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:
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...
__________________
lui è il mio amore: "tesò domani ti regalo un guinzaglio lungo 100 km"
monkey72 è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2003, 13:09   #3
cisky
Member
 
L'Avatar di cisky
 
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
Secondo me è sbagliato eseguire una SQL di questo tipo:

Quote:
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!
cisky è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2003, 16:30   #4
dani&l
Bannato
 
L'Avatar di dani&l
 
Iscritto dal: Nov 2000
Città: mi
Messaggi: 18791
Quote:
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.
dani&l è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2003, 13:20   #5
cisky
Member
 
L'Avatar di cisky
 
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
cisky è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2003, 19:57   #6
cisky
Member
 
L'Avatar di cisky
 
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
cisky è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
I coupon nascosti di Amazon si rinnovano...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 00:40.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v