Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-01-2007, 10:08   #1
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1383
[mysql] Lavorare con più tabelle.

Vorrei riuscire a fare a ottenere i dati di una tabella nell'ordine di quanto ricorrono in un altra tabella i campi che hanno in comune:

Ho una tabella NOMI (1 campo) e una tabella ETA' (2 campi):

NOMI

giovanni
maria
giovanni
crescenzo
federico
maria
giovanni

ETA

ma 15
cr 32
gi 24
fe 12

Vorrei ottenere:
24
15
32
12

Perchè Giovanni ricorre 3 volte nella tabella nomi e quindi l'età di giovanni viene per prima, maria ricorre 2 volte e dunque la sua età viene per seconda etc. Ho anche il problema che nella tabella età i nomi non sono per esteso ma ce n'è solo una parte.

Qualcuno sa come fare ?
Io ho fatto molte ricerche su internet ma l'unica cosa che sono riuscito a scoprire e l'uso di LIKE CONCAT("%",VARIABILE CON INIZIALE,"%") per trovare un nome avendone solo l'iniziale.


Grazie,

CIAO
das è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 12:44   #2
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1383
up
das è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 14:21   #3
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Guarda, presupposto che la situazione nella quale ti trovi ad operare mi fa orrore, dato che le relazioni tra entità non si tracciano così, questa query potrebbe fare al caso tuo:

Codice:
select e.eta
  from nomi n join eta e on n.nome like e.nome || '%'
group by e.eta
order by count(e.eta) desc
Ho creato due tabelle di prova su un mio db oracle e il risultato è il seguente:
Codice:
            ETA
-------------
              24
              15
              12
              32
Ovviamente così non hai la possibilità di sapere se uscirà prima il 12 o il 32, dato che una tabella è un'insieme e senza un'ulteriore clausola order by (esercizio) non hai nessuna certezza di ordinamento.

Comunque ripeto, un join basato sull'iniziale del nome è raccapricciante...
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 14:51   #4
giannola
Senior Member
 
L'Avatar di giannola
 
Iscritto dal: Oct 2005
Città: Palermo
Messaggi: 2579
Quote:
Originariamente inviato da shinya
Guarda, presupposto che la situazione nella quale ti trovi ad operare mi fa orrore, dato che le relazioni tra entità non si tracciano così, questa query potrebbe fare al caso tuo:

Codice:
select e.eta
  from nomi n join eta e on n.nome like e.nome || '%'
group by e.eta
order by count(e.eta) desc
Ho creato due tabelle di prova su un mio db oracle e il risultato è il seguente:
Codice:
            ETA
-------------
              24
              15
              12
              32
Ovviamente così non hai la possibilità di sapere se uscirà prima il 12 o il 32, dato che una tabella è un'insieme e senza un'ulteriore clausola order by (esercizio) non hai nessuna certezza di ordinamento.

Comunque ripeto, un join basato sull'iniziale del nome è raccapricciante...
mi accodo al raccapriccio, anche perchè nella tabella compaiono due giovanni e dunque creare una chiave esterna su valori che non sono a loro volta chiavi è pericoloso.

p.s. il tuo ordinamento è giusto in quanto federico compare prima di giovanni (il secondo)
__________________
Utente gran figlio di Jobs ed in via di ubuntizzazione
Lippi, perchè non hai convocato loro ?

Ultima modifica di giannola : 19-01-2007 alle 14:54.
giannola è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 15:59   #5
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Quote:
Originariamente inviato da giannola
p.s. il tuo ordinamento è giusto in quanto federico compare prima di giovanni (il secondo)
Si, nell'ultima frase mi riferivo ai valori 12 e 32, che hanno un solo nome ciascuno. Con la query che gli ho dato, l'ordine di questi ultimi due valori è arbitrario.
Ma vabbè...fosse questo il problema!
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 17:46   #6
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1383
Quote:
Originariamente inviato da shinya
Guarda, presupposto che la situazione nella quale ti trovi ad operare mi fa orrore, dato che le relazioni tra entità non si tracciano così, questa query potrebbe fare al caso tuo:
Sì ma la situazione non me la sono scelta perchè devo modificare un programma che già esiste ed è nato per uno scopo diverso da quello per cui lo voglio usare.
L'esempio che ho portato con i nomi è solo una semplificazione della situazione su cui devo operare.

In pratica sto cercando di modificare il motore di ricerca PHPDig ( che uso nel sito in signature ) che oridina i risultati per quanto ricorre la parola cercata nel file trovato.
Io voglio invece che li ordini per per numero di click ricevuti e che dia maggior peso a quei file in cui la parola cercata si trova all'inizio.

Per non modificare il programma in modo radicale ma solo la query sql e poche altre cose devo accettare compromessi in quanto a pulizia del software.

Una cosa però non riesco a capire:
perchè una stessa query sql ripetuta svariate volte in alcuni casi ordina i risultati in modo comunque giusto ma diverso?
Non dovrebbe dare sempre lo stesso risultato?


Grazie per la query che mi hai inviato, appena posso la provo. Ciao
das è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 18:03   #7
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Quote:
Originariamente inviato da das
Una cosa però non riesco a capire:
perchè una stessa query sql ripetuta svariate volte in alcuni casi ordina i risultati in modo comunque giusto ma diverso?
Non dovrebbe dare sempre lo stesso risultato?


Grazie per la query che mi hai inviato, appena posso la provo. Ciao
Una tabella è un insieme di elementi. Un insieme non ha ordine. Se non metti un order by non hai nessuna certezza sull'ordine dei risultati. Nel caso specifico hai due record con 1 sola occorrenza. La prima order by per count() fa si che vengano per ultimi. E' il db che decide se mettere prima il 12 o il 32. Dipende da tante cose. Probabilmente il 12 veniva prima in memoria. Se in oracle faccio un "alter table move", è possibile che non sia più così...se vuoi prima il 32 del 12 devi mettere un'altra order by desc su quel campo in aggiunta a quella esistente.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 18:22   #8
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1383
Quote:
Originariamente inviato da shinya
Una tabella è un insieme di elementi. Un insieme non ha ordine. Se non metti un order by non hai nessuna certezza sull'ordine dei risultati. Nel caso specifico hai due record con 1 sola occorrenza. La prima order by per count() fa si che vengano per ultimi. E' il db che decide se mettere prima il 12 o il 32. Dipende da tante cose. Probabilmente il 12 veniva prima in memoria. Se in oracle faccio un "alter table move", è possibile che non sia più così...se vuoi prima il 32 del 12 devi mettere un'altra order by desc su quel campo in aggiunta a quella esistente.
Ah pensavo che pur non avendo un ordine prestabilito mysql restituisse sempre i soliti risultati, va bè mi basta dirgli di ordinarli.

Adesso però ho un problema:
sono riuscito finalmente a costruire la query che mi serve


$query = "SELECT spider.spider_id,count(c_url) as weightA, spider.site_id, '2'
FROM ".PHPDIG_DB_PREFIX."keywords as k,".PHPDIG_DB_PREFIX."engine as engine, ".PHPDIG_DB_PREFIX."spider as spider left join ".PHPDIG_DB_PREFIX."clicks as clicks on clicks.c_url like concat('%',spider.file) and not spider.file=''
WHERE engine.key_id = k.key_id ".$ccc[$n]." ".$kconds[$n]."
AND engine.spider_id = spider.spider_id $wheresite $wherepath
GROUP BY clicks.c_url, spider.spider_id,spider.site_id

UNION

SELECT spider.spider_id,count(c_url) as weightA, spider.site_id, '0'
FROM ".PHPDIG_DB_PREFIX."keywords as k,".PHPDIG_DB_PREFIX."engine as engine, ".PHPDIG_DB_PREFIX."spider as spider left join ".PHPDIG_DB_PREFIX."clicks as clicks on clicks.c_url like concat('%',spider.file) and not spider.file=''
WHERE engine.key_id = k.key_id ".$cca[$n]." ".$kconds[$n]."
AND engine.spider_id = spider.spider_id $wheresite $wherepath
GROUP BY clicks.c_url, spider.spider_id,spider.site_id";


utilizzando XAMPP con mysql5 funziona perfettamente, ma quando la carico sul server di godaddy.com dove è installato mysql4,
alla prima ricerca mi da i risultati,
alla seconda me ne da molti meno
dalla terza in poi non funziona più.

Eppure in locale con XAMPP sto usando lo stesso identico database che ho in remoto.

Cosa può essere?

Ciao
das è offline   Rispondi citando il messaggio o parte di esso
Old 21-01-2007, 09:33   #9
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1383
up
das è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Project Windless: il nuovo action in esc...
Saros: mostrato il gameplay del gioco de...
God of War: Sons of Sparta annunciato e ...
John Wick torna in un nuovo videogioco a...
MADE chiude il 2025 con 59 partner e 250...
007 First Light: allo State of Play un n...
Gli iPhone su Amazon costano meno che su...
Credevi fosse un assistente IA, invece e...
God of War Trilogy Remake annunciato all...
Star Wars Galactic Racer mostra il gamep...
Legacy of Kain: Defiance Remastered annu...
Control Resonant si mostra allo State of...
Battlefield 6 Stagione 2: l'avanzata del...
Stop a umidità e muffa: deumidificatore ...
Trump l'anti-scientifico: la mossa per a...
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: 14:03.


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