Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-03-2013, 15:03   #1
Lelex82
Member
 
Iscritto dal: Mar 2006
Città: Napoli
Messaggi: 170
[SQL] Select di elementi

Salve ragazzi,
vi porrò probabilmente un quesito banale, ma io non riesco ad uscirne.
Dunque, la specifica è la seguente: voglio estrarre dalla tabella gli OID_USER che hanno OID_ROLE = 1 e OID_ROLE = 3

Tabella
OID | OID_USER | OID_ROLE
1 | 1 | 1
2 | 2 | 3
3 | 3 | 3
4 | 1 | 3
5 | 5 | 1

Quindi in teoria il risultato della query dovrebbe essere

OID | OID_USER | OID_ROLE
1 | 1 | 1
4 | 1 | 3

GRAZIE
Lelex82 è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2013, 15:40   #2
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Codice:
.... where OID_ROLE  in (1,3)
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2013, 16:22   #3
Lelex82
Member
 
Iscritto dal: Mar 2006
Città: Napoli
Messaggi: 170
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
Codice:
.... where OID_ROLE  in (1,3)
se uso questo comando, il risultato sono tutte i record che hanno O OID_ROLE = 1 O OID_ROLE = 3, io invece voglio i record in cui gli utenti hanno associati OID_ROLE = 1 E OID_ROLE =3
Lelex82 è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2013, 16:23   #4
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da Lelex82 Guarda i messaggi
voglio estrarre dalla tabella gli OID_USER che hanno OID_ROLE = 1 e OID_ROLE = 3

Tabella
OID | OID_USER | OID_ROLE
1 | 1 | 1
2 | 2 | 3
3 | 3 | 3
4 | 1 | 3
5 | 5 | 1

Quindi in teoria il risultato della query dovrebbe essere

OID | OID_USER | OID_ROLE
1 | 1 | 1
4 | 1 | 3

GRAZIE
Il risultato non soddisfa la specifica o sbaglio? Forse vuoi estrarre gli OID che hanno OID_USER = 1 e OID_ROLE = 1 o 3?
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo

Ultima modifica di ESSE-EFFE : 15-03-2013 alle 16:25.
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2013, 16:43   #5
Lelex82
Member
 
Iscritto dal: Mar 2006
Città: Napoli
Messaggi: 170
Il risultato che ho espresso originariamente è quanto mi aspetterei da una query che non riesco a costruire.
Probabilmente non riesco a spiegarmi perchè sono confuso...
dunque io voglio estrarre dalla tabella tutti i record dove ogni OID_USER ha OID_ROLE = 1 e OID_ROLE = 3.
Il caso specifico io lo devo generalizzare per una mia applicazione, in altri termini ho come parametro di confronto gli OID_ROLE e devo estrarmi gli OID_USER che hanno precisamente tutti gli OID_ROLE messi a confronto (quindi credo sia una AND tra gli OID_ROLE).
Lelex82 è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2013, 17:01   #6
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da Lelex82 Guarda i messaggi
Il risultato che ho espresso originariamente è quanto mi aspetterei da una query che non riesco a costruire.
Probabilmente non riesco a spiegarmi perchè sono confuso...
dunque io voglio estrarre dalla tabella tutti i record dove ogni OID_USER ha OID_ROLE = 1 e OID_ROLE = 3.
Il caso specifico io lo devo generalizzare per una mia applicazione, in altri termini ho come parametro di confronto gli OID_ROLE e devo estrarmi gli OID_USER che hanno precisamente tutti gli OID_ROLE messi a confronto (quindi credo sia una AND tra gli OID_ROLE).
Se ho capito quello che ti serve e ipotizzando che la tabella si chiami T, prova qualcosa del genere:

Codice:
SELECT T.OID, T.OID_USER, T.OID_ROLE
FROM T LEFT JOIN
    (SELECT OID_USER, COUNT(OID_USER) AS C
     FROM T
     WHERE (OID_ROLE = 1) OR (OID_ROLE = 3)
     GROUP BY OID_USER) AS T2 ON T.OID_USER = T2.OID_USER
WHERE (T2.C > 1)
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 00:39   #7
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
SELECT oid_user FROM Tabella WHERE OID_ROLE=1
INTERSECT
SELECT oid_user FROM Tabella WHERE OID_ROLE=3

che e' SQL 99 standard
Se il vostro motore non ce l'ha, non e' standard e pertanto fa pena.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2013, 09:23   #8
Lelex82
Member
 
Iscritto dal: Mar 2006
Città: Napoli
Messaggi: 170
entrambe le query ritornano risultati compatibili.
Sorge però un malfunzionamento quando inserisco, nel caso specifico un 3° ruolo per l'utente con OID_USER = 1: nel dettaglio
Tabella
OID | OID_USER | OID_ROLE
1 | 1 | 1
2 | 2 | 3
3 | 3 | 3
4 | 1 | 3
5 | 5 | 1
6 | 1 | 2 (nuovo record rispetto alla tabella precedente)

Se volessi tutti gli OID_USER che hanno associati SOLO i ruoli 1 AND 3, le query che mi avete gentilmente proposto non ritornano il risultato voluto, ma mi ritorna sempre OID_USER = 1 (il che nel caso specifico non è vero, perchè allo User 1 è associato anche il ruolo 2)
Lelex82 è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2013, 09:43   #9
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da Lelex82 Guarda i messaggi
Se volessi tutti gli OID_USER che hanno associati SOLO i ruoli 1 AND 3, le query che mi avete gentilmente proposto non ritornano il risultato voluto, ma mi ritorna sempre OID_USER = 1 (il che nel caso specifico non è vero, perchè allo User 1 è associato anche il ruolo 2)
Basta fare una INTERSECT con gli OID_ROLE richiesti (come già mostrato) a cui aggiungere una EXCEPT con gli OID_ROLE diversi da quelli richiesti.
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2013, 09:51   #10
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Basta fare una INTERSECT con gli OID_ROLE richiesti (come già mostrato) a cui aggiungere una EXCEPT con gli OID_ROLE diversi da quelli richiesti.
o MINUS su Oracle (EXCEPT non lo supporta)
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Samsung è sempre più prota...
ChatGPT ha pregiudizi politici? Ecco cos...
Un solo iPhone rubato ha portato alla sc...
Xiaomi 17 Ultra sta arrivando: ecco come...
Il Motorola Edge 70 non ha più se...
Alcuni Galaxy S26 utilizzeranno il chip ...
Amazon, ecco i super sconti del weekend:...
Scovare un bug di sicurezza sui disposit...
Offerta Amazon su NordVPN: proteggi 10 d...
ECOVACS DEEBOT X8 PRO OMNI in offerta su...
Scope elettriche Tineco in offerta su Am...
Offerta Amazon sui robot EUREKA J15 Ultr...
Chrome disattiverà automaticament...
Tornano tutti e 4 i colori disponibili p...
Super sconto su iPhone 16: Amazon abbass...
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: 01:08.


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