Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 01-04-2010
Avatar de sisne
sisne sisne is offline
Miembro
 
Registrado: mar 2010
Posts: 71
Poder: 15
sisne Va por buen camino
Actualizacion de Datos en varios Forms

Hola!
En esta ocasion quisiera saber si hay alguna manera de poder actualizar una misma tabla cuando se encuentra en varios Forms.
Ejemplo: Tabla1 ingreso datos en el Fomr1 y Tabla2 Ingreso datos Fomr2 pero algunos datos llamo de la otra Tabla1, es decir no ingreso solo llamo esos datos. Pero de pronto me encuentro en la Form1 y realizo algunos cambios y me voy al Form2 y ahi pues quisiera que se actualice los datos del Fomr1 cuando ingreso nuevos datos para el Form2.

Lo que puse fue cuando voy al form2, una vez que realizo las modificaciones en el Form1:
Código:
DM.Tabla1.Close;
DM.Tabla2.open;
Pero esto tengo que hacer varia veces en varios Forms y pues solo ocupa lineas codigo y tiempo.
Por que a veces en un mismo Form tengo datos que solo llamo de otros Forms, pero cuando camnbio los datos pues no se me actualiza cuando requiero ingresar nuevos datos

Gracias
Responder Con Cita
  #2  
Antiguo 01-04-2010
Avatar de yapt
yapt yapt is offline
Miembro
 
Registrado: sep 2006
Ubicación: España
Posts: 258
Poder: 18
yapt Va por buen camino
Hola Sisne,

no te entiendo bien. Tienes acceso a una tabla desde Form1 y Form2. Pero en el ejemplo que indicas, cierras Tabla1 y abres Tabla2.

En cualquier caso si accedes a la misma tabla (situada en un DataModule como parece el caso), desde 2 forms, los datos deberian actualizarse solos (siempre y cuando estemos hablando de componentes-delphi DBAware). En el caso de que no sea así, puedes utilizar:
Código Delphi [-]
Tablax.refresh;

Saludos.
Responder Con Cita
  #3  
Antiguo 01-04-2010
Avatar de sisne
sisne sisne is offline
Miembro
 
Registrado: mar 2010
Posts: 71
Poder: 15
sisne Va por buen camino
Hola!
Me explico:
En Form1- están los datos de la Tabla1, ahi tengo botones de Agregar, Guardar, Eliminar, Modificar, etc....
Y lo mismo en Form2- están los datos de la Tabla2, ahi tengo botones de Agregar, Guardar, Eliminar, Modificar, etc....
Ambos con ambos datos respectivos, solo que en el Form2 llama datos del Form1, por decir
Código:
DM.Tabla2['Form2Nombre']:=DM.Tabla1['Form1Nombre']
En el primer proceso todo bien.
Pero cuando decido realizar algun cambio en el Form1 (Tabla1), a pesar de hacer edit o refresh en el mismo (Claro en el Form1 se modifican y se actualizan y los guardo). Los datos usados del Form1 para el Form2 no se actualizan.
Por ello coloqué ese codigo de abrir y cerrar Tabla1 antes de ingresar al Form2, y pues solo de esta manera se actualizan..

Lo que quiero saber es que si talvez hay otra posibilidad para que se actualicen automanticamente todas las tablas al momento de ingresar a cualquieR Form. Ya que en si estoy usando en un FormX varias tablas. Pienso quizás exista algun opcion en Propiedades, Eventos de las tablas que desconozco.

Gracias por su ayuda.
Responder Con Cita
  #4  
Antiguo 06-04-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola sisne.

Creo que la solución empieza por esta pregunta:

¿ Como se entera el código: DM.Tabla2['Form2Nombre']:=DM.Tabla1['Form1Nombre'], de que realizaste un cambio en DM.Tabla1 ?

O dicho de otro modo: ¿Cuando le decis decis a la Tabla2 que realizaste un cambio en Tabla1 y que tiene que actualizarse ?

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 06-04-2010 a las 05:39:38.
Responder Con Cita
  #5  
Antiguo 06-04-2010
Avatar de sisne
sisne sisne is offline
Miembro
 
Registrado: mar 2010
Posts: 71
Poder: 15
sisne Va por buen camino
Hola ecfisa!
Empezaré de nuevo. Tengo datos en los form1 y Form2 con sus respectivas Tabla1 y Tabla2.
Ejemplo
Tabla1: CantidadMaterias,Sancion,CantidadReprobadas,CantidadAprobadas
Tabla2:MontoRecibir,MontoTotal
Donde MontoTotal es el resultado de:
MontoRecibir-MontoRecibir*Sancion*CantidadReprobadas.

Pero habiendo el caso de que disminuyera o hubiera una modificacion de la cantidadReprobadas en el Form1(Edit,Post), quiero que tb ese dato se actualice cuando me encuentre en el Form2 para un siguiente calculo o rsultado en el Form2.

Me funciona solo cuando coloco:
DM.tabla1.Close;
DMTabla1.Open;
Eso coloco en cuanto hago click en el boton Calcular, al inicio del codigo para realizar la operacion de MontoTotal que se encuentra en el Form2.

Gracias por el interes!
Graaacias.
Responder Con Cita
  #6  
Antiguo 06-04-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola sisne.

Ahora sí entiendo el problema...

Te hago otra pregunta: ¿ Estas usando CachedUpdates o Transactions que puedan afectar a Tabla1 ?

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 06-04-2010 a las 19:43:36.
Responder Con Cita
  #7  
Antiguo 08-04-2010
Avatar de sisne
sisne sisne is offline
Miembro
 
Registrado: mar 2010
Posts: 71
Poder: 15
sisne Va por buen camino
Hola ecfisa,

Pues te comento que no estoy usando CachedUpdates....

Solo quisiera saber como puedo hacer para que se actualice todas las modificaciones automaticas..

Gracias ecfisa
Responder Con Cita
  #8  
Antiguo 08-04-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola sisne.
Mirá, pense que lo había entendido pero se me ha echo un barullo con tu problema , a ver si te voy siguiendo...
En el primer post pusiste:
Cita:
En esta ocasion quisiera saber si hay alguna manera de poder actualizar una misma tabla cuando se encuentra en varios Forms.
La respuesta es: Todas, por que una misma tabla se va a ver igual desde cualquier form. Es decir que si haces un cambio
y lo guardas, luego pasas a otro form donde tenes un DBGrid con un DataSource apuntando a esa tabla, vas a ver el cambio sin lugar a dudas.
En el segundo post:
Cita:
Pero cuando decido realizar algun cambio en el Form1 (Tabla1), a pesar de hacer edit o refresh en el mismo (Claro en el Form1 se modifican y se actualizan y los guardo). Los datos usados del Form1 para el Form2 no se actualizan.
Ahora la cosa cambia, en este caso queres que un campo de la Tabla2 (MontoTotal) se actualize automáticamente al modificarse
alguno de los siguentes campos de la Tabla1: MontoRecibir, Sancion o CantidadReprobadas.
Bueno en este caso vas a tener que aprovechar algún evento de dichos campos para hacer los calculos pertinentes en Table2. Me parece apropiado el vento OnChange de los campos asociados.

Ejemplifico de acuerdo a los datos que pasaste:
Código:
procedure TDM.MontoRecibirChange(Sender: TField);
begin
   with Table2 do
   begin
      if not (State in dsEditModes) then Edit;
      MontoTotal:= MontoRecibir-MontoRecibir*Sancion*CantidadReprobadas;
      Post;
  end;
end;
Lo mismo para Sancion y CantidadReprobadas.

Por último desconozco el diseño de tus Tablas:
¿ MontoTotal es un solo registro ? ¿ Existe un MontoTotal por cada alumno ? ( supongo que son alumnos..)


Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 08-04-2010 a las 14:06:05.
Responder Con Cita
  #9  
Antiguo 08-04-2010
Avatar de sisne
sisne sisne is offline
Miembro
 
Registrado: mar 2010
Posts: 71
Poder: 15
sisne Va por buen camino
Hola ecfisa.
Asi es son de alumnos.
Tengo las siguientes tablas realizadas en SQL Server.
Tuniversitario:IdE,ci, nombre, apellidos...etc...
Tmateria:IdM, IdE,siglamateria,nombre materia,semestreanualizado.Calificacion...
Tbeca:IdB,IdE, montoArecibir, Cantsancion, MontoRecibido, CantidadReprobadas.. MontoTotalRecibido
TCantSancion:Sancion,MontoRecibir1,MontoRecibir2

En tabla cant sancion ya tengo establecidas las saciones y lo montos a recibir por diferentes lugares a los cuales pertenecen cada universitario.

Luego ya tengo los datos introducidos..
Una vez realizados los calculos respectivos, se decide cambiar los montos a recibir o cambiar las sanciones o modificar las calificaciones...cualquiera de esos aspectos..

Lo que deseo es que si se realizan esos cambios en la Tbeca con los cambios se actualicen los datos en esta tabla montoArecibir, Cantsancion, CantidadReprobadas.. y obviamente se actulice el MontoRecibido.

Espero haber aclarado bien...
Lo que estaba haciendo es en el FormBeca, al ingresar. Coloque el codigo de:
Código:
Tmateria.close;
Tmateria.open;
TUniversitario.close;
Tuniversitario.open;
Y en el mismo form habilite un boton ACTUALIZAR donde actulizaba con el campos y codigo repetido del boton NUEVO. Solo cambié en cuenta de insert, coloqué edit.

Intentaré con lo que me sugieres, gracias eh!
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
Crear un form fsMDIForm y varios forms hijos citlalliDgp Varios 11 07-12-2007 15:13:31
¿Como puedo trabajar con varios forms en delphi PHP? fredo PHP 1 13-06-2007 18:20:06
Varios forms, frames y un Data Module gluglu Varios 1 07-04-2005 19:28:51
Funciones comunes a varios Forms gluglu Varios 10 06-01-2005 20:23:04
problema con app con varios forms y barra de tareas kalisto Varios 1 15-08-2004 17:25:15


La franja horaria es GMT +2. Ahora son las 07:22:25.


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