Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Manejar Tablas con Muchos datos (https://www.clubdelphi.com/foros/showthread.php?t=85049)

hondaalberto 19-01-2014 02:00:59

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.

Casimiro Notevi 19-01-2014 11:07:36

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:
Código SQL [-]
select nombre, telefono from tbClientes where campo1=? and campo2=? and campo3=? ....

Ñuño Martínez 19-01-2014 14:52:04

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:
Código SQL [-]
SELECT nombre, telefono FROM tbClientes WHERE campo1=? AND campo2=? .... LIMIT ?, ?
Aunque no sé si MS-SQL lo acepta.

olbeup 20-01-2014 07:57:15

Cita:

Empezado por Ñuño Martínez (Mensaje 471897)
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:
Código SQL [-]
SELECT nombre, telefono FROM tbClientes WHERE campo1=? AND campo2=? .... LIMIT ?, ?
Aunque no sé si MS-SQL lo acepta.

Hay que cambiar el LIMIT por TOP

Código SQL [-]
SELECT TOP 100 nombre, telefono FROM tbClientes WHERE campo1=? AND campo2=?

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

Ñuño Martínez 20-01-2014 11:27:15

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.

hondaalberto 20-01-2014 15:20:56

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.

santiago14 21-01-2014 00:07:44

Muchos componentes TQuery tienen una propiedad que ayuda a controlar la cantidad de registros que devuelven, por lo general está en 0 (cero), que le indica que se traiga todos los valores.
A veces se llama "Buffer", o cosas por el estilo.
Eso sí, no podemos traer 2.000.000 de registros, hay que filtrar por algún criterio.

Santiago.

Neftali [Germán.Estévez] 21-01-2014 08:30:16

De todas formas hay que cambiar el enfoque.
Conceptualmente no basta con limitar lo que se muestra, creo que hay que limitar la consulta.
No se puede abrir un cursor sobre la tabla de 2 m. de registros.


La franja horaria es GMT +2. Ahora son las 05:29:05.

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