Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-04-2003, 10: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, 14: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, 14: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, 17: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, 14: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, 20: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


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 20:30.


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