Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 04-11-2023
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.354
Poder: 19
Angel.Matilla Va por buen camino
¿Por qué no usa el índice?

Tengo este query que ejecuto en FB 2.5.6:
Código SQL [-]
SELECT A.Codigo, A.Nombre, RDB$GET_CONTEXT('USER_TRANSACTION', 'MUNICIPIO') Municipio,
       RDB$SET_CONTEXT('USER_TRANSACTION', 'MUNICIPIO', 
                                     (SELECT DISTINCT Municipio FROM Mesas WHERE CodPrv = B.CodPrv AND Codigo = B.Mesa))
  FROM Partidos A, Resultados B, Poblacion C
 WHERE A.CodPrv = :PrvIns AND A.Codigo > 0
   AND A.CodPrv = B.CodPrv AND A.Codigo = B.Partido AND B.Proceso = :Proceso
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?
Responder Con Cita
  #2  
Antiguo 04-11-2023
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.264
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
No sé si será porque todavía no me he tomado el café, pero no veo dónde usas la tabla "Poblacion".
Responder Con Cita
  #3  
Antiguo 04-11-2023
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.264
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Supongo que será esto:
Código SQL [-]
(SELECT DISTINCT c.Municipio FROM Mesas c WHERE c.CodPrv = B.CodPrv AND c.Codigo = B.Mesa))
Responder Con Cita
  #4  
Antiguo 04-11-2023
Avatar de mamcx
mamcx mamcx is offline
Moderador
 
Registrado: sep 2004
Ubicación: Medellín - Colombia
Posts: 3.927
Poder: 26
mamcx Tiene un aura espectacularmamcx Tiene un aura espectacularmamcx Tiene un aura espectacular
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.
Responder Con Cita
  #5  
Antiguo 05-11-2023
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.757
Poder: 21
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
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.

Código SQL [-]
SELECT A.Codigo, A.Nombre, RDB$GET_CONTEXT('USER_TRANSACTION', 'MUNICIPIO') Municipio,
       RDB$SET_CONTEXT('USER_TRANSACTION', 'MUNICIPIO', 
                                     (SELECT DISTINCT Municipio FROM Mesas WHERE CodPrv = B.CodPrv AND Codigo = B.Mesa))
FROM Partidos A, Resultados B, Poblacion C
WHERE 
A.CodPrv = :PrvIns AND 
A.Codigo > 0 AND 
A.CodPrv = B.CodPrv AND 
A.Codigo = B.Partido AND 
B.Proceso = :Proceso

Esto podría escribirse con JOINs de la siguiennte manera:
Código SQL [-]
SELECT A.Codigo, A.Nombre, RDB$GET_CONTEXT('USER_TRANSACTION', 'MUNICIPIO') Municipio,
       RDB$SET_CONTEXT('USER_TRANSACTION', 'MUNICIPIO', 
                                     (SELECT DISTINCT Municipio FROM Mesas WHERE CodPrv = B.CodPrv AND Codigo = B.Mesa))
FROM Partidos A 
JOIN Resultados B on A.CodPrv = B.CodPrv AND A.Codigo = B.Partido
JOIN Poblacion C on 1=1
WHERE 
A.CodPrv = :PrvIns AND 
A.Codigo > 0 AND 
B.Proceso = :Proceso

No entiendo qué es lo que buscas con las partes CONTEXT.
Responder Con Cita
  #6  
Antiguo 06-11-2023
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.354
Poder: 19
Angel.Matilla Va por buen camino
Unhappy

Cita:
Empezado por Casimiro Notevi Ver Mensaje
No sé si será porque todavía no me he tomado el café, pero no veo dónde usas la tabla "Poblacion".
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.
Responder Con Cita
  #7  
Antiguo 06-11-2023
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.354
Poder: 19
Angel.Matilla Va por buen camino
Cita:
Empezado por duilioisola Ver Mensaje
No entiendo qué es lo que buscas con las partes CONTEXT.
Como estoy haciendo pruebas, pues es una de las que he hecho.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

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


La franja horaria es GMT +2. Ahora son las 19:49:09.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi