FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Manejar Tablas con Muchos datos
Buenas Noches Amigos
Utilizo Delphi 7 y Microsoft SQL Server 2008, y tengo una tabla con mas de 2,000,000 de registros. Lo que me gustaria saber es como puedo mostrar esos datos o con que componente conectarme a la base de datos ya que intente hacerlo con um componente TTable y un DBGrid y me dio un Error de memoria por la gran cantidad datos y el fomulario se pone muy lento cuando esta haciendo este proceso. Probe con componente TQuery y un DBGrid y me pasa lo mismo. Me gustaria Saber si debo utilizar otros componentes en estos casos o hacer alguna otra cosa. Muchas Gracias a Todos por su tiempo invertido en ayudarme. |
#2
|
||||
|
||||
El problema es que quieres cargar 2 millones de registros en memoria y presentarlos.... ¿para qué?, ¿alguien va a recorrer un grid con 2 millones de registros?
Debes hacer... lo que hay que hacer, o sea, filtrar. Si vas a buscar por nombre, por código, los que tengan un apellido determinado, un DNI, etc. y devolver siempre los menos registros posibles, y si es posible, solamente uno, el que se necesita y ninguno más. Para eso debes usar SQL, evidentemente:
|
#3
|
||||
|
||||
Además de lo que dice el compañero Camisiro, no hace falta que obtengas todos los registros de golpe: también puedes paginarlos usando LIMIT:
Aunque no sé si MS-SQL lo acepta. |
#4
|
||||
|
||||
Cita:
Pero esto no tiene sentido extraer solo lo "x Registros" de una SQL, lo mejor filtrar por un campo o xx campos, como dice casimiro Un saludo
__________________
Al hacer una consulta SQL, haz que los demás te entiendan y disfruten de ella, será tú reflejo de tú saber. |
#5
|
||||
|
||||
En realidad no es "extraer sólo x registros" sino paginar los resultados. Así: "LIMIT 1, 50" te extrae los primeros 50, "LIMIT 51, 50" los siguientes 50, "LIMIT 101, 50" sería la tercera página. De esta forma vas manejando de 50 en 50 (o los que sean) lo cual puede ahorrarte memoria dependiendo de lo que estés haciendo.
|
#6
|
|||
|
|||
Voy a probar las Recomendaciones que me dan Compañeros. Muchas Gracias por sus ideas y su tiempo. mas adelante comento como me fue. Gracias.
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Manejar dos tablas independientes en un mismo Formulario(Access) | feliz-58 | Varios | 10 | 19-07-2013 04:52:44 |
Ado Excel muchos datos | Delfino | Conexión con bases de datos | 9 | 22-03-2011 09:48:56 |
Mostrar en un DBGRID Relacion Muchos Muchos | dmassive | SQL | 6 | 12-02-2009 18:55:19 |
¿Recomendable muchos campos? o... ¿varias tablas.? | anghell77 | Tablas planas | 14 | 15-11-2006 11:18:51 |
Consejo para manejar tablas Paradox | Coco_jac | Varios | 8 | 17-11-2005 17:27:17 |
|