Salve.
Ho un db mysql composto di 3 tabelle. Una piccola (una 50ina di record), una media (c.a. 30K di record), una immensa (c.a. 5M di record). chiamiamole A,B,C
Le tre tabelle sono legate in cascata così:
campi
A: id: chiave primaria; txt-a: varchar
B: id: chiave primaria; a-id: puntamento ad A.id; txt-b: varchar
C: id: chiave primaria; a-id: puntamento ad A.id; b-id: puntamento a B.id; txt-c: varchar
i campi sono legati con foreign key
io devo cercare un record in C e devo tirare fuori i relativi record di A e B
select A.txt-a, B.txt-b, C.txt-c from C left join B on C.b-id=B.id left join B on B.a-id=A.id where txt-c like '%pippo%'
a seconda dei casi la query può impiegare anche 2 minuti.
In qualche caso, da ricercare ho anche chiavi su txt-a e/o txt-b. Questo significa che potrei limitare la ricerca ad un ristretto numero di record di C, il che potrebbe accellerare di molto la ricerca.
Tuttavia ricerche come
select A.txt-a, B.txt-b, C.txt-c from C left join B on C.b-id=B.id left join B on B.a-id=A.id where txt-a = 'pluto' and txt-c like '%pippo%'
non velocizzano assolutamente la ricerca.
Qualcuno sa come sfruttare quel pluto per ridurre effettivamente il numero di record su cui cercare?
In pratica mi aspetterei cose tipo "tira fuori A.id rispondenti a txt-a='pluto' e cerca 'pippo' solo nei record di C con C.id-a corrispondenti alla ricerca precedente"
Grazie
01



)