Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-02-2013, 11:57   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[MySql]Join 'where in' ...

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:

Codice:
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 !!
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 09-02-2013, 12:53   #2
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
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, ma si appoggia ad una tabella temporanea con nome fisso, quindi quando si fanno due query contemporanee... poi chissà le performance...)
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 10-02-2013, 13:53   #3
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da Gimli[2BV!2B] Guarda i messaggi
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.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 10-02-2013, 17:20   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
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.

Codice:
WHERE INSTR(   ','||c.ID||','   ,    ','||b.extid||','  ) != -1
__________________
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 11-02-2013, 14:36   #5
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
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.

Codice:
WHERE INSTR(   ','||c.ID||','   ,    ','||b.extid||','  ) != -1

Ora vedo anche così

Avevo però risolto con la funzione substring_index:

Codice:
SELECT substring_index('mercoledi', settimana, 3) as giorno, 
FROM tabella
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
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...
L'intelligenza artificiale ha reso pi&ug...
L'intelligenza artificiale per lo svilup...
Il sistema di verifica dell'identit&agra...
Ora è ufficiale: Samsung sta per ...
Motorola Edge 70 Fusion: ecco le specifi...
8TB a meno di 170€: il richiestissimo Ha...
Il nuovo MacBook 'low cost' arriver&agra...
Pokémon Rosso Fuoco e Verde Fogli...
Risparmiare con le offerte Amazon: weeke...
Gli Xiaomi 17 arrivano a fine febbraio, ...
48.000 Pa a poco più di 100€: la ...
PC più potente, meno spesa: su Amazon to...
Con 2 acquisti si ottiene il 40% di scon...
Blocco VPN in Spagna durante le partite ...
ECOVACS DEEBOT T30C OMNI GEN2 torna a 34...
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: 22:29.


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