Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

 
 
Herramientas Buscar en Tema Desplegado
  #16  
Antiguo 23-09-2016
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is online now
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 19.437
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por javierin_ Ver Mensaje
Buenos días.

Neftalí, el findkey lo utilizo para hacer una búsqueda en una tabla. Es muy efectivo y fácil, ya que a medida que vas tecleando la palabra a buscar, ves cómo va recorriendo la tabla (en un dbgrid) con gotokey y/o gotonearest. Empecé a usarlo porque observé que, en una búsqueda un tanto complicada para realizar un informe en una tabla con varios miles de registros, el locate tardaba demasiado (del orden de varios minutos), mientras que con el findkey, el mismo algoritmo y la misma tabla tardaba unos cuantos segundos.
Ya te digo que soy algo novato con las mysql, así que qué me recomiendas? Volver al locate quizá??
¿Qué base de datos utilizabas antes con el BDE?
Imagino que una Base de Datos en local. Es lo que te comento, el problema no es del LOCATE/FINDKEY es algo asociado a la Base de Datos.

En las BD locales todos los datos están en memoria, por eso findkey, locate o lo que usaras va rápido.
Cuando utilizas una BD servidor, esa idea de tener los datos en local desaparece y lo que priva es minimizar el tráfico de datos (porque lo normal para estas bases de datos, es que van a estar en un servidor y no te puedes traer toda la tabla a local para hacer una búsqueda incremental).

La recomendación no es usar un método u otro, sino eliminar la utilización de la búsqueda incremental (en general).

Si por lo que sea tienes una tabla relatívamente pequeña, puedes cargar la en memoria con algún componente y realizarla, pero no es lo que se aconseja y en todo caso no hacerlo directamente sobre el servidor, sino como te he dicho sobre una tabla que préviamente has cargado en memoria. Pero como te he dicho eso de "traer la tabla completa a memoria" no es nada recomendable y no es una buena práctica.
NOTA: Por ejemplo, si la aplicación va a ser monopuesto y el servidor está en la misma máquina puedes hacerlo, pero entonces deberías plantearte si necesitar usar un "Servidor de Base de Datos" para esto. Tal vez estés escogiendo mal la tecnología a utilizar. En este caso
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
error mysql en componente zeoslib giulichajari Conexión con bases de datos 1 31-08-2014 06:30:53
Conexion con ZeosLib a Mysql Remoto ander Conexión con bases de datos 5 03-07-2014 12:07:17
Ejecutable (mysql+zeoslib) vmorillos MySQL 8 27-12-2010 17:49:18
Ayuda con una consulta de MySQL desde Delphi con ZeosLib...!! NeySmall Varios 3 17-04-2008 22:22:50
ZeosLib y MySQL 5 onlytk Conexión con bases de datos 2 31-12-2005 03:37:52


La franja horaria es GMT +2. Ahora son las 19:16:38.


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