![]() |
¿Por qué no usa el índice?
Tengo este query que ejecuto en FB 2.5.6:
y las estadísticas que me da IBManager me han dejado perplejo: ![]() Las tablas implicadas en ese RDB$SET_CONTEXT están indexadas por CodPrv y Municpio (tabla Mesas) y CodPrv y Codigo como índice primario de la tabla Poblacion; ¿cómo es posible que no use ningún índice para realizar ese SELECT? |
No sé si será porque todavía no me he tomado el café, pero no veo dónde usas la tabla "Poblacion".
|
Supongo que será esto:
|
El query planner es de lo mas complejo que tiene la BD (yo estoy trabajando en uno y es algo grande, y apenas estoy en lo basico!).
El query planer puede que no use indices porque: - La heurísticas de la BD le indican que es mas trabajoso usar indices que un scan directo (la selectividad es muy pequeña) - Las consultas están "dentro" de funciones que el planner no puede ver. Así que si `RDB$GET_CONTEXT` es una función con un WHERE/JOIN dentro eso es invisible fuera de esa funcion - La mayoría de los RDBMS son pésimos al usuario consultas dentro de consultas. Considera que solo `WHERE + ORDER BY+ JOIN` entra en los cálculos y las demás opciones como `HAVING, GROUP BY, ...` tal vez no. - Un motor viejo tiene probablemente un peor query planner: Ya miraste si una version reciente "resuelve" esto? |
Parece que en ningún momento filtras la tabla POBLACION. Por eso el planner la lee completamente.
Suongo que te da los resultados repetidos tantas veces como poblaciones tengas en esa tabla.
Esto podría escribirse con JOINs de la siguiennte manera:
No entiendo qué es lo que buscas con las partes CONTEXT. |
Cita:
|
Cita:
|
La franja horaria es GMT +2. Ahora son las 05:26:32. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi