FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Consulta muy lenta
Buenas
Estoy programando una aplicacion pero para que se entienda voy a simplifacarla en un ejemplo mas comun. En mi aplicacion tengo lo siguiente: 1) Una base de datos (Paradox) con los campos: provincia localidad nombre 2) Tres querys atadas entre si que muestran: 1ra.) provincia 2da.) localidad filtrada por provincia (atada a la query1) 3ra.) nombre filtrada por provincia+localidad (atada a la segunda) 3) Tres dbcombobox que seleccionan: 1ro.) campo provincia 2do.) localidad 3ro.) nombre. Mi problema es que a medida que voy haciendo busquedas se va poniendo cada vez mas lento al desplegar los dbcombobox. La forma en que até las querys es poniendo en el SQL String lo siguiente: 1ra) Select distinct provincia from "base.db" order by provincia. 2da) Select distinct localidad, provincia from "base.db" where provincia=rovincia order by localidad. DataSource: Datasource1. 3ra) Select distinct nombre, localidad, provincia from "base.db where provincia=rovincia and localidad=:localidad order by nombre. Datasource2 Qué es lo que estoy haciendo mal? Muchas gracias. |
#2
|
||||
|
||||
¿Están indexados los campos por los que estas filtrando?... ¿Existe algún índice combinado?
Sucede que si la tabla tiene una gran colección de datos y estos no están indexados, el motor se verá obligado a consultar uno por uno los registros para encontrar los coincidentes, y esto demorará la consulta dependiendo de la cantidad de datos de la tabla. Otro tema es la estructura de los índices, por ejemplo si tenemos un índice por provincia y otro por localidad y ninguno mas, y filtramos por ambos campos, al motor solo le servirá uno de estos índices y depende de cada motor como decirle cual tome primero, por eso si siempre va a haber búsquedas combinadas es conveniente pensar bien el diseño de los índices. Saludos!
__________________
delphi.com.ar Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla. |
#3
|
|||
|
|||
Muchas gracias por tu respuesta!!!
La verdad es que la base no está indexada, voy a probar por ese lado y cualquier cosa te cuento. Un abrazo y gracias de nuevo. Saludos Walter |
|
|
|