FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Como mejorar la velocidad en este caso....
Hola compañeros!
Tengo un problema que deseo compartir con ustedes: Trabajo cun una base de datos de Paradox indexada por un codido unico (típico). en la tablita exite otro campo memo en el cual guardo una cantidad indeterminada de nombres y apellidos separados por comas, ejemplo: PEDRO PEREZ, JUAN CUALQUIERA, MANUEL NOMEACUERDO...., NOMBE APELLIDO Para buscar en cuantos proyectos trabajo alguien, mando una consulta asi: Código:
select * from proyecto.db where grupo like %nombreapellido% El caso es que tarda media vida en devolver los datos... no puedo indexar por alli porque es un campo memo. Aunque creo haber leido que los tquerys no hacen uso de los indices(?perdonen si estoy rebusnando, y corrijanme) El caso es que no puedo usar un campo string, porque en varios casos la lista de personas sobrepasa los 256 caracteres y en casos especiales pudieran aparecer en listas 150 personas (calculen a razon de 20 caracteres por persona). Realmente quiciera implementar otro metodo o quiza forma de almacenar en la base de datos o lo que sea ..., se me ocurria algo como cun campo lookup a una tabla que se cargue con todas las personas, pero dudo en como inplantar la busqueda, el campo nombreapellido almasenaria una cadena como: 25,358,1208,5,10254 y creo que es la misma moneda vista desde otro angulo......... Alguien tiene una mejor idea que esta ideota! Se agracede el esfuerzo... y se aceptan sugerencias y regaños
__________________
if Vivir = Vivir + Aprender then Aprender = ? Alfredo Borges |
#2
|
||||
|
||||
y por qué no tienes una tabla con los nombres y su campo código, ese sería el índice que estaría relacionado con la tabla de proyectos
¿o acaso no he entendido bien el problema? |
#3
|
||||
|
||||
Creo que la idea que te da Casimiro es buena, ya que el planteamiento actual es prácticamente inviable. En cuanto al tema índices, pues resulta que las consultas no los utilizan, yo al menos he hecho pruebas de rendimiento con índices y sin ellos y el tiempo era exactamente el mismo, (estamos hablando de Paradox).
Un Saludo.
__________________
Guía de Estilo de los Foros Cita:
|
#4
|
||||
|
||||
Yo también considero que el punto central aquí es el planteamiento de la estructura relacional. Y por lo que colijo, no se trataría de añadir sólamente la tabla de nombres sino además una tabla asociativa ya que parece que la relación entre proyectos y empleados es n-n.
Tendrías tus tablas: Código:
empleados = (id, nombre) proyectos = (id, descripcion) asignaciones = (empleado_id, proyecto_id)
Y usas el id obtenido para buscar en la tabla de asignaciones:
Con lo que obtienes la lista de ids de los proyectos en que participó el empleado. Por supuesto puedes usar joins para obtener directamente los proyectos, por ejemplo:
o directamente con el nombre del empleado:
En cualquier forma que uses ten en cuenta que la búsqueda con like puede devolverte más de un registro. Por otra parte, tal como comenta Marcos, Paradox no parece hacer uso de los índices en consultas SQL. Por ello, contrario a lo que se recomendaría en servidores SQL, en bases de escritorio resulta mucho más eficiente usar componentes TTable en lugar de TQuery, sobre todo si tus tablas son muy grandes. Para este caso, por ejemplo, podrías tener componentes tblEmpleados, tblProyectos y tblAsignaciones. Poniendo a tblEmpleados como master de tblAsignaciones, en cuanto localices al empleado (con tblEmpleados.Locate o tblEmpleados.FindKey si tienes un índice sobre el campo nombre), la componente tblAsignaciones automáticamente se filtrará con únicamente las asignaciones del empleado. Semánticamente es lo mismo que hacer la relación por SQL pero más eficiente. // Saludos |
#5
|
|||
|
|||
agradecido...
Les agradezco a todos las ideas... voy a hacer ambas pruebas... en el caso de las consultas las pasare a FB... y las mantendre para probar con Ttables... luego comento...
__________________
if Vivir = Vivir + Aprender then Aprender = ? Alfredo Borges |
|
|
|