Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   InserciÓn De Registro Con Maestro-detalle (https://www.clubdelphi.com/foros/showthread.php?t=26421)

perillan 22-10-2005 15:10:04

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

marcoszorrilla 22-10-2005 15:57:22

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

perillan 22-10-2005 18:32:00

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í.

vtdeleon 23-10-2005 00:12:52

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í ;)

vtdeleon 23-10-2005 00:18:44

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;

perillan 23-10-2005 11:15:23

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


La franja horaria es GMT +2. Ahora son las 02:13:49.

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