Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 19-01-2014
hondaalberto hondaalberto is offline
Miembro
 
Registrado: sep 2010
Ubicación: República Dominicana
Posts: 67
Poder: 14
hondaalberto Va por buen camino
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.
Responder Con Cita
  #2  
Antiguo 19-01-2014
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
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=? ....
Responder Con Cita
  #3  
Antiguo 19-01-2014
Avatar de Ñuño Martínez
Ñuño Martínez Ñuño Martínez is offline
Moderador
 
Registrado: jul 2006
Ubicación: Ciudad Catedral, Españistán
Posts: 6.000
Poder: 25
Ñuño Martínez Tiene un aura espectacularÑuño Martínez Tiene un aura espectacular
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.
__________________
Proyectos actuales --> Allegro 5 Pascal ¡y Delphi!|MinGRo Game Engine
Responder Con Cita
  #4  
Antiguo 20-01-2014
Avatar de olbeup
olbeup olbeup is offline
Miembro
 
Registrado: jul 2005
Ubicación: Santiago de la Ribera (España)
Posts: 685
Poder: 19
olbeup Va camino a la fama
Cita:
Empezado por Ñuño Martínez Ver Mensaje
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
__________________
Al hacer una consulta SQL, haz que los demás te entiendan y disfruten de ella, será tú reflejo de tú saber.
Responder Con Cita
  #5  
Antiguo 20-01-2014
Avatar de Ñuño Martínez
Ñuño Martínez Ñuño Martínez is offline
Moderador
 
Registrado: jul 2006
Ubicación: Ciudad Catedral, Españistán
Posts: 6.000
Poder: 25
Ñuño Martínez Tiene un aura espectacularÑuño Martínez Tiene un aura espectacular
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.
__________________
Proyectos actuales --> Allegro 5 Pascal ¡y Delphi!|MinGRo Game Engine
Responder Con Cita
  #6  
Antiguo 20-01-2014
hondaalberto hondaalberto is offline
Miembro
 
Registrado: sep 2010
Ubicación: República Dominicana
Posts: 67
Poder: 14
hondaalberto Va por buen camino
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.
Responder Con Cita
  #7  
Antiguo 21-01-2014
Avatar de santiago14
santiago14 santiago14 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Cerrillos, Salta, Argentina
Posts: 583
Poder: 21
santiago14 Va por buen camino
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.
__________________
Uno es responsable de lo que hace y de lo que omite hacer.
Responder Con Cita
  #8  
Antiguo 21-01-2014
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.275
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
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.
__________________
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
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

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


La franja horaria es GMT +2. Ahora son las 18:27:01.


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