Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-05-2010, 16:40   #1
ang3lx
Senior Member
 
L'Avatar di ang3lx
 
Iscritto dal: Apr 2006
Città: Battipaglia
Messaggi: 510
[PHP/MYSQL] selezione lista amici in comune

Salve ragazzi,
ho un problema con una query. ho necessità di crearmi un array con gli amici in comune

la tabella è strutturata nel seguente modo

id toid fromid
1 1 2
2 2 1
3 1 3
4 3 1
.. .. ..
e così via

quindi per ogni amicizia c'è andata e ritorno (:P)

come posso strutturare la query in modo che esca un array con la lista di id in comune di $_SESSION[id] (vitatore) $_GET[iduser] (visitato)?

Ringrazio tutti in anticipo
Nello
__________________
iMAC PRO XeonW 32GB // Samsung S21 Ultra // PS5 // Synology DS218+
TRATTATIVE concluse: neorunner,Luca.81,macca_BD,leleweb,frax289,Hnk,pitro,filosofo24,ivvo,papaiti,ale.zak91
Seguimi su http://blog.webeats.it
ang3lx è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2010, 18:37   #2
vhost87
Senior Member
 
L'Avatar di vhost87
 
Iscritto dal: Apr 2008
Città: Varese
Messaggi: 406
Quote:
Originariamente inviato da ang3lx Guarda i messaggi
Salve ragazzi,
ho un problema con una query. ho necessità di crearmi un array con gli amici in comune

la tabella è strutturata nel seguente modo

id toid fromid
1 1 2
2 2 1
3 1 3
4 3 1
.. .. ..
e così via

quindi per ogni amicizia c'è andata e ritorno (:P)

come posso strutturare la query in modo che esca un array con la lista di id in comune di $_SESSION[id] (vitatore) $_GET[iduser] (visitato)?

Ringrazio tutti in anticipo
Nello
Devi estrarre TUTTE le corrispondenze dove c'è visitatore (SESSION) e visitato (USER ID) ?

Se si bastano un normale AND o OR sulla Query, dipende da cosa vuoi che ritorni; prova ad specificare meglio la richiesta (non tanto il problema, che è presentato in maniera completa).
__________________
IT Developer at Hardware Upgrade S.r.l.
self.love(this.me());
vhost87 è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2010, 18:52   #3
ang3lx
Senior Member
 
L'Avatar di ang3lx
 
Iscritto dal: Apr 2006
Città: Battipaglia
Messaggi: 510
Quote:
Originariamente inviato da vhost87 Guarda i messaggi
Devi estrarre TUTTE le corrispondenze dove c'è visitatore (SESSION) e visitato (USER ID) ?

Se si bastano un normale AND o OR sulla Query, dipende da cosa vuoi che ritorni; prova ad specificare meglio la richiesta (non tanto il problema, che è presentato in maniera completa).
ti ringrazio in primis per la risposta.
veniamo alla richiesta. come risultato voglio tutti gli id degli amici che abbiamo in comune

esempio pratico, così mi spiego ancora meglio. uso la tabella di prima

id toid fromid
1 1 2
2 2 1
3 1 3
4 3 1

se io (che ad esempio ho id 2) visito la pagina della persona con id 3, l'output della query che mi interessa dovrebbe essere 1 (amicizia in comune)
__________________
iMAC PRO XeonW 32GB // Samsung S21 Ultra // PS5 // Synology DS218+
TRATTATIVE concluse: neorunner,Luca.81,macca_BD,leleweb,frax289,Hnk,pitro,filosofo24,ivvo,papaiti,ale.zak91
Seguimi su http://blog.webeats.it
ang3lx è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2010, 19:03   #4
vhost87
Senior Member
 
L'Avatar di vhost87
 
Iscritto dal: Apr 2008
Città: Varese
Messaggi: 406
Quote:
Originariamente inviato da ang3lx Guarda i messaggi
ti ringrazio in primis per la risposta.
veniamo alla richiesta. come risultato voglio tutti gli id degli amici che abbiamo in comune

esempio pratico, così mi spiego ancora meglio. uso la tabella di prima

id toid fromid
1 1 2
2 2 1
3 1 3
4 3 1

se io (che ad esempio ho id 2) visito la pagina della persona con id 3, l'output della query che mi interessa dovrebbe essere 1 (amicizia in comune)
LOL mi dicevi le amicizie in comune capivo al volo, perdonami ma alle 20 di sera dopo una giornata di lavoro inizio a perdere qualche colpo.

La strada è semplice; tu hai 2 dati sicuri:

A) l'ID del tuo profilo
B) l'ID del profilo che stai visitando

Ora devi estrarre TUTTI gli utenti che contiene l'ID della colonna (toid); non vedo la difficoltà, basta un SELECT * FROM tabella WHERE toid = VALORE;

Forse sono io che sono ko ma mi pare che la terza colonna non abbia senso di esistere se necessiti dei soli amici in comune; se invece la terza colonna corrisponde SEMPRE al tuo ID e ti serve per un controllo di sicurezza integra un AND dopo il WHERE.

Ci siamo? (entrambi però :P)
__________________
IT Developer at Hardware Upgrade S.r.l.
self.love(this.me());
vhost87 è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2010, 19:12   #5
ang3lx
Senior Member
 
L'Avatar di ang3lx
 
Iscritto dal: Apr 2006
Città: Battipaglia
Messaggi: 510
ahah non lo dire a me

in effetti è vero, le uniche cose sicure sono

A) l'ID del tuo profilo (che sta in $_SESSION[id])
B) l'ID del profilo che stai visitando (che sta in una variabile $row_visitato[id])

facendo la query che dici tu, cioè "SELECT * FROM tabella WHERE toid = VALORE;"
vengono printati si tutte le amicizie, ma non solo quelle in comune come serve a me

guarda quest'altra strada (che non so perchè non funziona)
avevo provato anche questa strada qui (sicuramente moooolto più avida di risorse)
Codice:
	$amicizie_visitato = mysql_query("SELECT toid FROM friends WHERE fromid = '$_GET[id]' ");
	$amicizie_visitatore = mysql_fetch_array(mysql_query("SELECT toid FROM friends WHERE fromid = '$_SESSION[id]' "));
	
	
	print("<br /><br />Amicizie $_GET[id] ");
	while($rowamc1 = mysql_fetch_array($amicizie_visitato)){
		if(array_search($rowamc1["toid"],$amicizie_visitatore) === TRUE){
			print(" $rowamc1[toid] ");
		}
	}
in poche parole avevo pensato di mettere in $amicizie_visitatore gli id degli amici del visitatore e fare un check amicizia per amicizia del VISITATO se erano contenute in questo array.

oppure ancora un'altra soluzione poteva essere quella di fare
un array delle amicizie del visitatore, uno di quelle del visitate e poi fare un intersezione dei 2 array

sto perdendo colpi
__________________
iMAC PRO XeonW 32GB // Samsung S21 Ultra // PS5 // Synology DS218+
TRATTATIVE concluse: neorunner,Luca.81,macca_BD,leleweb,frax289,Hnk,pitro,filosofo24,ivvo,papaiti,ale.zak91
Seguimi su http://blog.webeats.it
ang3lx è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2010, 07:41   #6
vhost87
Senior Member
 
L'Avatar di vhost87
 
Iscritto dal: Apr 2008
Città: Varese
Messaggi: 406
A quel punto meglio se usi una IN di MySQL

SELECT * FROM tabella WHERE IN(ID1, ID2, ID3, ID4)

__________________
IT Developer at Hardware Upgrade S.r.l.
self.love(this.me());
vhost87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2010, 11:21   #7
ang3lx
Senior Member
 
L'Avatar di ang3lx
 
Iscritto dal: Apr 2006
Città: Battipaglia
Messaggi: 510
ho risolto con questa query qui. a chi può interessare/servire

SELECT TC.fromid FROM
(SELECT fromid FROM friends WHERE toid='$_SESSION[id]') TC JOIN
(SELECT fromid FROM friends WHERE toid='$row_id[id]') TP ON TC.fromid=TP.fromid


però provo anche la tua soluzione!
__________________
iMAC PRO XeonW 32GB // Samsung S21 Ultra // PS5 // Synology DS218+
TRATTATIVE concluse: neorunner,Luca.81,macca_BD,leleweb,frax289,Hnk,pitro,filosofo24,ivvo,papaiti,ale.zak91
Seguimi su http://blog.webeats.it
ang3lx è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2010, 13:23   #8
vhost87
Senior Member
 
L'Avatar di vhost87
 
Iscritto dal: Apr 2008
Città: Varese
Messaggi: 406
Subqueries
Facci sapere
__________________
IT Developer at Hardware Upgrade S.r.l.
self.love(this.me());
vhost87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2010, 13:43   #9
ang3lx
Senior Member
 
L'Avatar di ang3lx
 
Iscritto dal: Apr 2006
Città: Battipaglia
Messaggi: 510
Quote:
Originariamente inviato da vhost87 Guarda i messaggi
Subqueries
Facci sapere
allora sembra che anche la tua query va molto bene. l'ho sviluppata così:

Codice:
SELECT friends.fromid FROM friends WHERE fromid IN($_SESSION[id],$row_id[id]) GROUP BY fromid
ho messo il group by per eliminare le occorrenze.

però ho 2 domande:
1) ho provato a fare un join per prendere anche l'username dalla tabella users, ma con questo metodo non ci riesco proprio
2) a livello computazionale è meglio l'IN vero?
__________________
iMAC PRO XeonW 32GB // Samsung S21 Ultra // PS5 // Synology DS218+
TRATTATIVE concluse: neorunner,Luca.81,macca_BD,leleweb,frax289,Hnk,pitro,filosofo24,ivvo,papaiti,ale.zak91
Seguimi su http://blog.webeats.it
ang3lx è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2010, 14:32   #10
vhost87
Senior Member
 
L'Avatar di vhost87
 
Iscritto dal: Apr 2008
Città: Varese
Messaggi: 406
Quote:
Originariamente inviato da ang3lx Guarda i messaggi
allora sembra che anche la tua query va molto bene. l'ho sviluppata così:

Codice:
SELECT friends.fromid FROM friends WHERE fromid IN($_SESSION[id],$row_id[id]) GROUP BY fromid
ho messo il group by per eliminare le occorrenze.

però ho 2 domande:
1) ho provato a fare un join per prendere anche l'username dalla tabella users, ma con questo metodo non ci riesco proprio
2) a livello computazionale è meglio l'IN vero?
Ti rispondo al contrario, prima la 2 poi la 1.
2) Non lo so, non so che algoritmi usa MySQL e ho il terrore a guardarli sinceramente. Su PGSQL sicuramente è il TOP per questo genere di lavori (ti riserva di ciclare una query o di usare un AND ogni volta...); alternativa sarebbe il = ANY () ma non funziona proprio come la IN (anzi si usano in circostanze completamente opposte e diverse).

1) la JOIN la puoi fare, dipende come la strutturi ovviamente
__________________
IT Developer at Hardware Upgrade S.r.l.
self.love(this.me());
vhost87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Come un MacBook, ma con la RTX 5070: MSI...
Paolo Zaccardi: "Smettere di assume...
Finalmente a buon prezzo 2 mini PC con R...
Samsung Galaxy Watch 7: uno crolla a 146...
NVIDIA pronta al 'piano B' per la Cina: ...
Xiaomi TV A Pro 55 a soli 366€: è...
No, i tuoi dati di Pokémon Go non sono f...
XBOX potrebbe diventare una societ&agrav...
Il primo trilionario al mondo ha un nome...
Infineon apre il 2 luglio lo Smart Power...
Crimson Desert non si ferma: il gioco di...
Con iOS 27 l'iPhone si ripristina da sol...
Visa porta i pagamenti in ChatGPT: gli a...
OpenAI valuta un 'drastico' taglio dei p...
Il MacBook con display touch si far&agra...
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:00.


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