Ver Mensaje Individual
  #16  
Antiguo 23-09-2016
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.278
Reputación: 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