FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
¿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? |
#2
|
||||
|
||||
No sé si será porque todavía no me he tomado el café, pero no veo dónde usas la tabla "Poblacion".
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#3
|
||||
|
||||
Supongo que será esto:
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#4
|
||||
|
||||
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?
__________________
El malabarista. |
#5
|
||||
|
||||
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. |
#6
|
||||
|
||||
Tienes razón. Como estoy probando varias formas de ejecutar esa consulta, quitando y poniendo tablas, se ve que aquí se me olvidó quitar esa tabla del query.
|
#7
|
||||
|
||||
Como estoy haciendo pruebas, pues es una de las que he hecho.
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
problema con indice | voldemmor | SQL | 2 | 14-04-2009 17:29:54 |
Indice en el ClientDataSet | Nelly | Varios | 1 | 22-10-2007 22:56:41 |
Busqueda por indice | noe | Firebird e Interbase | 3 | 04-10-2004 19:45:22 |
Indice incorrecto | VolaRe | Varios | 8 | 22-02-2004 21:34:45 |
Problema con Índice | KayserSoze | Firebird e Interbase | 2 | 29-01-2004 16:12:43 |
|