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 29-03-2007
ddd_ddd ddd_ddd is offline
Miembro
 
Registrado: sep 2005
Posts: 60
Poder: 20
ddd_ddd Va por buen camino
como actualizar un quickreport?

tengo una tabla que se llama "temporal", esta tabla solo me sirve para guardar datos que son resultados de una query1 y una query2. pero cuando trato de imprimir con un quickreport los datos que guardé en la tabla temporal, me imprime resultados anteriores.

este es mi codigo en un boton que te llama imprimir:
Código Delphi [-]
QUERY2.FindFirst;
QUERY1.FindFirst;
FOR I:=1 TO 4 DO
  BEGIN
    query3.ParamByName('Nombre').AsString:=dbedit23.Text;
    query3.ParamByName('Numero').AsString:=dbedit22.Text;
    query3.ParamByName('Renglon').Asfloat:=I;
    try
      query3.ExecSQL;
     except
       showmessage('error en la query3');
    end;
    query2.Next;
    query3.Next;
  END;
  QUERY6.ACTIVE:=FALSE;
todo funciona bien, si abro la tabla en ese momento tengo los 4 resultados que yo queria como los queria.
el problema es cuando llega al quickrep1.preview.
es un quickreport en otro formulario que llamo desde éste con:
Código Delphi [-]
form26.QuickRep1.refresh;
form26.QuickRep1.preview;
el el formulario 26 tengo una query1 que lo unico que hace es:
Código SQL [-]
select * from temporal
y este es el problema, la primera vez que lo ejecuto el programa, al presionar el boton de imprimir, no me muestra ni imprime ningun dato, pero los datos si se guardan correctamente en la tabla temporal, vamos a suponer que los datos de la primera ejecucion fueron arturo, berenice, martin y diego.
cierro el programa y lo vuelvo a ejecutar, y cuando presiono el boton imprimir, ahora deberia mostrarme los resultados nuevos que son: azul, rojo, amarillo y verde. pero en lugar de estos resultados me imprime los que debio haber impreso en la ejecucion anterior, imprime: arturo, berenice, martin y diego.
osea siempre me imprime los resultados que generé la ultima vez antes de cerrar el programa, y solo esos.
que estoy haciendo mal?
Responder Con Cita
  #2  
Antiguo 29-03-2007
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Es de suponer que la consulta
Código SQL [-]
Select From Temporal

la ejecutas antes de abrir QuickReport sino es normal que no te funcione.

Sino es así puede ocurrir que las consultas que ejecutas previamente y que pueblan esa tabla temporal no hayan descargado su memoria intermedia.

Prueba antes de Select from Temporal, a forzar a las consultas a vaciar su memoría, dependerá la instrucción a ejecutar del tipo de tablas utilizado, desde FlushBuffers hasta cerrar y abrir la tabla de nuevo.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #3  
Antiguo 29-03-2007
ddd_ddd ddd_ddd is offline
Miembro
 
Registrado: sep 2005
Posts: 60
Poder: 20
ddd_ddd Va por buen camino
estoy usando delphi 7 y las tablas las hice en paradox, como vacio la memoria intermedia? porque la tabla si está actualizada antes de que mandar imprimir la tabla temporal. puse un dbgrid para verificar que estubiera actualizada y si lo está.
yo creo que si cierro la base de datos y la vuelvo a abrir antes de imprimir, se soluciona el problema, pero alguien podria decirme como se hace eso??? lo estoy intentando pero ps no se como ajjaja
gracias

Última edición por ddd_ddd fecha: 29-03-2007 a las 23:47:36.
Responder Con Cita
  #4  
Antiguo 29-03-2007
ddd_ddd ddd_ddd is offline
Miembro
 
Registrado: sep 2005
Posts: 60
Poder: 20
ddd_ddd Va por buen camino
como cierro una base de datos

es una pregunta sencilla, tengo que imprimir el contenido de una tabla, pero me imprime la tabla con los datos que tenia la ultima vez que ejecuté el programa, entonces quiero cerrar la base de datos completa, y volverla a abrir antes de imprimir para solucionar mi problema. pero como lo hago, estoy usando delphi 7 y las tablas en paradox
gracias
Responder Con Cita
  #5  
Antiguo 30-03-2007
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Código Delphi [-]
MiQuery1.FlushBuffers;

{Para la tabla:}
MiTabla.Active:=False;
MiTabla.Active:=True;

y en cualquiera de los dos casos despues abres QuickReport.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #6  
Antiguo 30-03-2007
ddd_ddd ddd_ddd is offline
Miembro
 
Registrado: sep 2005
Posts: 60
Poder: 20
ddd_ddd Va por buen camino
intenté las dos formas, y me sigue pasando lo mismo, yo creo que la unica forma es cerrando y abriendo toda la base de datos, no solo una tabla, alguien sabe como hacerlo?
por favor
Responder Con Cita
  #7  
Antiguo 30-03-2007
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
En Paradox la base de datos y la tabla es lo mismo. Y la tabla se cierra como te he dicho anteriormente y También.

Código Delphi [-]
MiTabla.Close;
MiTable.Open;

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #8  
Antiguo 30-03-2007
Avatar de droguerman
droguerman droguerman is offline
Miembro
 
Registrado: abr 2005
Ubicación: tierra
Posts: 999
Poder: 20
droguerman Va por buen camino
Cita:
Empezado por ddd_ddd
intenté las dos formas, y me sigue pasando lo mismo, yo creo que la unica forma es cerrando y abriendo toda la base de datos, no solo una tabla, alguien sabe como hacerlo?
por favor
antes de hacer preview o print usa el método prepare;
Código Delphi [-]
quickreport.prepare;
quickreport.preview;
__________________
self.free;
Responder Con Cita
  #9  
Antiguo 30-03-2007
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
El problema de no "ver esos registros nuevos" viene por lo comentado por Marcos Zorrilla, En el afterPost de todas tus tablas tienes que poner Dataset.Flushbuffers. (Dataset es el parámetro del evento Afterpost, así, todas las tablas puedes ligarlas al mismo evento).

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
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
Como guardar .JPG como Bitmap en Base de Datos Javi2 Gráficos 4 25-03-2007 18:21:57
Como cierro mi aplicacion? MadeInBsAs Varios 3 04-06-2006 01:20:58
Como cierro un form desde un Applet maravert JAVA 0 14-09-2004 19:35:56
como cierro un secion del msn de hotmail click Varios 1 19-04-2004 00:29:08
Como conectarme a una base de datos como postgres o mysql?? marys MySQL 4 08-05-2003 12:34:08


La franja horaria es GMT +2. Ahora son las 01:00:04.


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