Hola.
El problema es que el locate se recorre toda la tabla buscando el registro que cumpla con la condición requerida y eso tiene poco arreglo.
Para hacer búsquedas con un query deberías de hacer un select con las condiciones y eso si que irá rápido.
Saludos
|