View Full Version : [MySql]Join 'where in' ...
RaouL_BennetH
08-02-2013, 10:57
Ciao ragazzi.
Ho tre tabelle dalle quali estrapolare ovviamente dei dati.
una di queste contiene dei valori in un campo tipo (12,15)
questi valori sono però id relativi ad un'altra tabella.
Per spiegarmi meglio:
SELECT a.*, b.*, c.*
FROM table1 as a
LEFT JOIN table2 as b
on a.extid = b.id
//FIN QUI OK
//ora dovrei prendere tutti i dati presenti nell'altra tabella
JOIN table3 as c
//e dirgli prendi tutto da 'c' dove gli id di 'c' sono contenuti
nel campo b.extid (es. 12,5,8)
Grazie mille !!
Gimli[2BV!2B]
09-02-2013, 11:53
Ma il campo table2.extid è una stringa contenente numeri separati da virgole?
Se è così personalmente non conosco un modo per utilizzare SQL liscio per ottenere quel che chiedi (ovviamente costruendo la select a runtime si può "tranquillamente" inserire la lista di ID in una condizione IN).
La cosa migliore sarebbe creare una tabella che mantenga una sana relazione uno a molti da table2.id a table3.id, con una coppia di ID per riga.
Ah, credo ci si possa anche inventare una stored procedure, ma non direi sia facilissimo farlo in modo decente (questo esempio è interessante (http://www.marcogoncalves.com/2011/03/mysql-split-column-string-into-rows/), ma si appoggia ad una tabella temporanea con nome fisso, quindi quando si fanno due query contemporanee... poi chissà le performance...)
RaouL_BennetH
10-02-2013, 12:53
;39002325']Ma il campo table2.extid è una stringa contenente numeri separati da virgole?
Si, è una stringa che contiene numeri separati da virgole.
Sospettavo che non ci fosse nulla da fare.
Ciò che suggerisci in seguito non posso applicarlo. Non ho modo nè di creare tabelle nè di gestire sp.
qualcosa simile a
WHERE INSTR(c.ID, b.extid) != -1
dove INSTR e' la funzione che restituisce il primo indice in cui la prima striga si riturova contenuta nella seconda
Ovviamente cosi' non funziona, perche' anche 45 e' contenuta in 123456, 234789 occorre
anteporre e postporre il separatore.
E cosi' facendo occorre anche anterporlo e postportlo nella stringa lunga.
WHERE INSTR( ','||c.ID||',' , ','||b.extid||',' ) != -1
RaouL_BennetH
11-02-2013, 13:36
qualcosa simile a
WHERE INSTR(c.ID, b.extid) != -1
dove INSTR e' la funzione che restituisce il primo indice in cui la prima striga si riturova contenuta nella seconda
Ovviamente cosi' non funziona, perche' anche 45 e' contenuta in 123456, 234789 occorre
anteporre e postporre il separatore.
E cosi' facendo occorre anche anterporlo e postportlo nella stringa lunga.
WHERE INSTR( ','||c.ID||',' , ','||b.extid||',' ) != -1
Ora vedo anche così :)
Avevo però risolto con la funzione substring_index:
SELECT substring_index('mercoledi', settimana, 3) as giorno,
FROM tabella
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.