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 22-10-2005
perillan perillan is offline
Miembro
 
Registrado: feb 2005
Posts: 82
Poder: 20
perillan Va por buen camino
InserciÓn De Registro Con Maestro-detalle

La base de datos es de interbase con una tabla Maestro y otra de Detalle.

Cuando doy de alta un registro (maestro y en detalle) necesito que esto a su vez quede registrado en otra base de datos llamada altas para control de altas anual. Lo tengo hecho con código pero tengo problemas en la base de altas con la detalle a la hora de poner el código. ¿ Hay algún componente que lo pueda hacer directamente?.

Un saludo
Responder Con Cita
  #2  
Antiguo 22-10-2005
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
Y nos podrías decir cuales son esos problemas para ver si podemos darte alguna solución.

Si aprovechas los eventos del componente que uses "afterInsert" por ejemplo y lanzas un Insert contra las otras 2 tablas, empezando claro está por la maestro y siguiendo por el detalle envueltas en la correspondiente transación no veo que problemas pueda darte.


Un Saludo.l
__________________
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 22-10-2005
perillan perillan is offline
Miembro
 
Registrado: feb 2005
Posts: 82
Poder: 20
perillan Va por buen camino
Te mando el codigo ya que esta un poco liado y nos podremos entender mejor

Código Delphi [-]

Comienzo para insertar un registro

procedure TPaneldeAltas.BitBtn130Click(Sender: TObject);

begin

dmmain.DataCompanies.active:=TRUE; //Tabla principal y maestra

dmmain.DataLocations.active:=TRUE;//Tabla principal hija

dmmain.DataCompanies.append;

dmmain.DataCompaniesBASEDATOS.Value:='CON NÚMERO (Z)';

DBEdit1.SetFocus;

end;



Cuando termino de meter los datos pulso boton

procedure TPaneldeAltas.BitBtn2Click(Sender: TObject);

var

fecha,fecha1,fecha2:string;

BEdit1,BEdit5,BEdit2,BEdit55,BEdit7,BComboBox6,BEdit9,BEdit10,BEdit11:string;

BEdit12,BEdit13,BEdit14,BEdit15,BEdit17,BEdit18,BEdit20,BComboBox1:string;

BComboBox5,BEdit23,BEdit24,BEdit3,BEdit4,BEDIT261:string;



begin

 fecha:=MaskEdit2.Text;

 fecha1:=MaskEdit3.Text;

 fecha2:=DateToStr(now);

  edit2.Text:=DateToStr(now);

//Asigno valores para las altas en la tabla altas

 bedit1:=DBEdit1.text;

bedit5:=DBEdit5.text;

 bedit2:=DBEdit2.text;

 bedit55:=DBEdit55.text;

 bedit7:=DBEdit7.text;

 bcombobox6:=DBComboBox6.text;

 bedit9:=DBEdit9.text;

 bedit10:=DBEdit10.text;

 bedit11:=DBEdit11.text;

 bedit12:=DBEdit12.text;

 bedit13:=DBEdit13.text;

 bedit14:=DBEdit14.text;

 bedit15:=DBEdit15.text;

 bedit17:=DBEdit17.text;

 bedit18:=DBEdit18.text;

 bedit20:=DBEdit20.text;

 bcombobox1:=DBComboBox1.text;

 bcombobox5:=DBComboBox5.text;

 bedit23:=DBEdit23.text;

 bedit24:=DBEdit24.text;

 bedit3:=DBEdit3.text;

 bedit4:=DBEdit4.text;

 BEDIT261:=DBEdit261.Text;

 ////

 dmmain.DataCompaniesFECHARECEP.AsString:= fecha;

           dmmain.DataCompaniesFECHAENTSERVICIO.AsString:= fecha1;

           dmmain.DataCompanies.insert;

 TRY

           dmmain.IBTransaction1.COMMIT;

EXCEPT

           SHOWMESSAGE ('Hay problemas con la transacion');

dmmain.IBTransaction1.ROLLBACK;



 END;

      SHOWMESSAGE ('Registro bien Insertado'); //Se ha insetado correctamente el registro en la tabla maestra



//Empezamos a pasar datos

dmmain.IBDataSetAltas.Active:=TRUE;

dmmain.IBDataSetAltas.APPEND;



 dmmain.IBDataSetAltasBASEDATOS.Value:='CON NÚMERO (Z)';

 dmmain.IBDataSetAltasNOMBRE.value:=BEdit1;

 dmmain.IBDataSetAltasControlZ.value:=BEdit5;

 dmmain.IBDataSetAltasNCODIGO.value:=BEdit2;

 dmmain.IBDataSetAltasNMATRICULA.value:=BEdit55;

 dmmain.IBDataSetAltasNSerie.AsString:=BEdit7;

 dmmain.IBDataSetAltasRUEDASCADENAS.AsString:=BComboBox6;

 dmmain.IBDataSetAltasVALORACION.AsString:=BEdit9;

 dmmain.IBDataSetAltasNCARGO.AsString:=BEdit10;

 dmmain.IBDataSetAltasCIADESTINO.AsString:=BEdit11;

 dmmain.IBDataSetAltasBONDESTINO.AsString:=BEdit12;

 dmmain.IBDataSetAltasNACTARECEP.AsString:=BEdit13;

 dmmain.IBDataSetAltasOBSERVA1.AsString:=BEdit14;

 dmmain.IBDataSetAltasOBSERVA2.AsString:=BEdit15;

 dmmain.IBDataSetAltasOBSERVA3.AsString:=BEdit17;

 dmmain.IBDataSetAltasOBSERVA4.AsString:=BEdit18;

 dmmain.IBDataSetAltasNOS.AsString:=BEdit20;

 dmmain.IBDataSetAltasTIPOMAQUINA.AsString:=BComboBox1;

 dmmain.IBDataSetAltasSITUACINO.AsString:=BComboBox5;

 dmmain.IBDataSetAltasNMotor.AsString:=BEdit23;

 dmmain.IBDataSetAltasNCHASIS.AsString:=BEdit24;

 dmmain.IBDataSetAltasNNOC.AsString:=BEdit3;

 dmmain.IBDataSetAltasNCABECERA.AsString:=BEdit4;

 dmmain.IBDataSetAltasFECHADEALTA.AsString:=fecha2;

dmmain.IBDataSetAltasSITUACINO.AsString:= BEDIT261;

 dmmain.IBDataSetAltasFECHARECEP.AsString:= fecha;

  dmmain.IBDataSetAltasFECHAENTSERVICIO.AsString:= fecha1;



dmmain.IBDataSetAltas.Last;

 dmmain.IBTAltasBajas.COMMIT;



end;





Si se necesitan introducir datos en la tabla principal hijo entonces pulso este boton

//Cuando hay datos a introducir en la base principal/hijo

procedure TPaneldeAltas.BitBtn111Click(Sender: TObject);

begin

dmmain.DataLocations.append;

DBEdit90.SetFocus;



dmmain.IBDataSetAltas.Active:=TRUE; //Eta base es la de registo de Altas maestro

dmmain.IBDataSetAltasImple.Active:=TRUE;// Esta  de registro de altas hijo

dmmain.IBDataSetAltas.append;

end;



//Cada vez que se introduce un registro  en base principal/hijo se pulse este boton

procedure TPaneldeAltas.BitBtn20Click(Sender: TObject);

var

grabar:string;

begin

   grabar:=MaskEdit400.Text;

   if MaskEdit400.text = '  /  /  ' then

         else

      dmmain.DataLocationsFECHAALTA.AsString:=grabar;

      dmmain.DataLocations.append;

DBEdit90.SetFocus;

end;

Con este codigo se insertan todo perfectamente menos en la tabla Hijo/de la maestro altas, en la que cada vez que se introduce un nuevo registro debe grabarse aquí.

Última edición por vtdeleon fecha: 23-10-2005 a las 01:14:22. Razón: Etiqueta Delphi
Responder Con Cita
  #4  
Antiguo 23-10-2005
Avatar de vtdeleon
vtdeleon vtdeleon is offline
Miembro
 
Registrado: abr 2004
Ubicación: RD & USA
Posts: 3.236
Poder: 24
vtdeleon Va por buen camino
Saludos
perillan, date una vuelta por Las Etiquetas, en especial las de delphi, para que puedas encerrar el codigo que tienes y asi poder tener el codigo mas legible.

Esta vez lo he hecho por tí
__________________
Van Troi De León
(Not) Guía, Code vB:=Delphi-SQL, ¿Cómo?
Viajar en el tiempo no es teóricamente posible, pues si lo fuera, ya estarían aqui contándonos al respecto!

Última edición por vtdeleon fecha: 23-10-2005 a las 01:14:57.
Responder Con Cita
  #5  
Antiguo 23-10-2005
Avatar de vtdeleon
vtdeleon vtdeleon is offline
Miembro
 
Registrado: abr 2004
Ubicación: RD & USA
Posts: 3.236
Poder: 24
vtdeleon Va por buen camino
Saludos

Veo que en 2 tablas solo haces append y no asignas valores a los campos, en el BitBtn111Click:
dmmain.DataLocations.append;
mmain.IBDataSetAltas.append;
__________________
Van Troi De León
(Not) Guía, Code vB:=Delphi-SQL, ¿Cómo?
Viajar en el tiempo no es teóricamente posible, pues si lo fuera, ya estarían aqui contándonos al respecto!
Responder Con Cita
  #6  
Antiguo 23-10-2005
perillan perillan is offline
Miembro
 
Registrado: feb 2005
Posts: 82
Poder: 20
perillan Va por buen camino
En dmmain.DataLocations.append no es necesario asignarle valores, ya que los asigna directamente al ser introducidos en los DBEdit.text que salen en pantalla.
No ocurre lo mismo con el mmain.IBDataSetAltas.append pues los DBEdit están enlazados con un DataSource a la tabla principal (DataCompanies/Padre y DataLocations/Hijo).

Si asigno valores en el BitBtn111Click a mmain.IBDataSetAltas estos se me insertaran en un registro y se duplicaran pues estos datos se registran al pulsar el BitByn2. Aqui es domde empiezan los problemas de mi consulta para ver como puedo hacer que los datos queden registrados en la base IBDataSetAltasImple/Hijo cuando los haya sabiendo que depende de la
IBDataSetAltas/Padre.

No se si me habre esplicado bien.
Un saludo
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


La franja horaria es GMT +2. Ahora son las 01:08:19.


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