Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
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: 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.
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: 18790
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


Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
iPhone 16 si trova ora su Amazon a soli ...
Amazon fa a pezzi i prezzi dei monitor g...
Componenti hardware e periferiche PC a p...
Pianeta in crisi: 7 su 9 limiti vitali g...
Galaxy S25 FE con taglio di prezzo di 10...
4 robot aspirapolvere e 3 scope elettric...
Nuovissimi Xiaomi 15T e 15T Pro con tagl...
Le agenzie federali americane potranno u...
Smartphone pieghevoli sempre più ...
LG svela le Easy TV, una nuova gamma di ...
L'equipaggio della missione Shenzhou-20 ...
Possibili detriti spaziali del razzo cin...
Amazon distrugge i prezzi: TV OLED LG, i...
Trump studia dazi fino al 100% per sping...
ASUS Vivobook Go 15 in offerta su Amazon...
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: 10:09.


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