Club Delphi  
    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 Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 14-11-2003
Pandre Pandre is offline
Miembro
 
Registrado: may 2003
Ubicación: San Bartolomé de la Torre, Huelva (España)
Posts: 35
Poder: 0
Pandre Va por buen camino
TADOTable al completo en memoria???

Hola a todos:

En mi aplicación accedo a una base de datos de Access mediante ADO, en la que hay una tabla con 42.000 registros. El caso, es que la aplicación ocupa en memoria casi 60 Mb y va muy lenta en los DBGrid.
En cambio, si la tabla es Paradox (también con los 42.000 registros) y accedo a ella mediante BDE, la aplicación sólo ocupa 6 Mb en memoria y los DBGrid van de maravilla.

Tengo estimado que la aplicación tenga que trabajar con unos 160.000 registros en varias tablas relacionadas. Para ello, necesito caracteristicas que me aporta Access, pero la aplicación sería mostruosa en memoria e iría muy lenta.

La pregunta es, ¿hay alguna forma de leer tablas mediante ADO pero que sean tratadas como las de BDE? Vamos, que no las cargue en memoria, sino que las lea cuando vaya siendo necesario.

Espero haberme explicado bien. Si no es así, reescribo el mensaje dando mas detalles.
Un saludo y muchísimas gracias por vuestra atención.
__________________
Un cordial saludo.

~~~~~~~~~~~~~~~~~~
José A. Gómez Martín
pandre@arsystel.com
Responder Con Cita
  #2  
Antiguo 14-11-2003
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola

Que yo sepa, no se puede emular la carga incremental de tablas que hace el BDE, en ADO.

Lo habitual en ADO es no trabajar con tantos datos, es decir en lugar de abrir toda la tabla (TADOTable), lanzas consultas (TADOQuery) que solo devuelvan los registros con los que vas a trabajar, y los campos que te interesa mostrar.

NOTA : En lugar de poner directamente los 40.000 registros en una grid, pones algún criterio de selección, que lanze una consulta, y muestre en la grid los registros que cumplen la condición (con lo que la grid solo estará conectada a unos centenares de registros). Recuerda de obtener en la consulta, solo los campos que vas a mostrar en la grid, no tiene ningún sentido que la consulta cargue campos que no se van a mostrar, como serian los comentarios en un campo Memo que pueden ser mucho espacio ocupado en memoria y tiempo de carga.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #3  
Antiguo 15-11-2003
Pandre Pandre is offline
Miembro
 
Registrado: may 2003
Ubicación: San Bartolomé de la Torre, Huelva (España)
Posts: 35
Poder: 0
Pandre Va por buen camino
Hola guillotmarc:

Ante todo, darte las gracias por tus sugerencias. La verdad es que es lógico lo que me comentas.

Pero esta respuesta es para decirte que he encontrado un completo set de componentes gratuito para ADO. Se llama KA DAO y esta muy bien.

Lógicamente, este paquete no tiene el problema que presentaba el ADO incluido en Delphi. Este se comporta igual que el BDE.

Lo he encontrado en Torry, así que si te interesa pues ya sabes.
__________________
Un cordial saludo.

~~~~~~~~~~~~~~~~~~
José A. Gómez Martín
pandre@arsystel.com
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


La franja horaria es GMT +2. Ahora son las 23:34:18.


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