Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   OOP (https://www.clubdelphi.com/foros/forumdisplay.php?f=5)
-   -   Crear ClientDataset Maestro/Detalle en tiempo de ejecucion. (https://www.clubdelphi.com/foros/showthread.php?t=94463)

hagsoft 21-02-2020 20:00:09

Crear ClientDataset Maestro/Detalle en tiempo de ejecucion.
 
Hola:


Mi Consulta es como hacer el relacionamiento de maestro detalle de 2 clientDataset que obtienen datos desde un Query por medio de datasetProvider he intentado pero no pude lograrlo. Mi duda es como pasar los parametros de la consulta para que se reflejen en el clientdataset detalle y ademas como hacer para crear el campo datasetfield para relacionar los dos clientdataset.


Gracias.



Código Delphi [-]
procedure TfrmSellGrid.Cliente;
var
  providerMaster:TDataSetProvider;
  cdsMaster,cdsDetail:TClientDataSet;
  dsMaster,dsourceMaster,dSourceDetail:TDataSource;
  SQLQuery1, SQLQuery2:TUniQuery;

  str:TDataSetField;
begin
  providerMaster:=TDataSetProvider.Create(nil);
  cdsMaster:=TClientDataSet.Create(nil);
  cdsDetail:=TClientDataSet.Create(nil);
  dsMaster:=TDataSource.Create(nil);
  dsourceMaster:=TDataSource.Create(nil);
  dSourceDetail:=TDataSource.Create(nil);
//  try

     SQLQuery1:=TUniQuery.Create(Self);
     SQLQuery2:=TUniQuery.Create(Self);

     dsMaster.DataSet:=SQLQuery1;


    with SQLQuery1 do
    begin
      Connection:=dm.dbaseConn;
      Close;
      SQL.Clear;
      SQL.Add('SELECT * FROM facturas');
      Open;
    end;
    with SQLQuery2 do
    begin
      Connection:=dm.dbaseConn;
      Close;
      SQL.Clear;
      SQL.Add('SELECT * FROM facturas_detalles');
      SQL.Add('WHERE idFactura = :idFactura');
      Open;
    end;

    providerMaster.DataSet:=SQLQuery1;
    cdsMaster.SetProvider(providerMaster);

    with TIntegerField.Create(Self) do
    begin
      Name := 'idFacturaa';
      FieldKind := fkData;
      FieldName := 'idFactura';
      DataSet := cdsMaster;
      Required := True;
    end; //ID

    //with TDataSetField.Create(Self) do
    ///begin
    //  Name := 'cdsMasterSQLQuery2';
    //  FieldName := 'SQLQuery2';
    //  DataSet := cdsMaster;
    //end;
    //cdsMaster.CreateDataSet;



  str := TDataSetField.Create(self);
  str.Name:='llave';
  str.FieldName := 'aa';
  str.FieldKind := fkData;
  str.Size := 10;
  SQLQuery1.Fields.Add(str);


    cdsDetail.DataSetField:=TDataSetField(FindComponent('llave'));
   

    cdsMaster.Open;
    SQLQuery2.MasterSource:=dsMaster;
    cdsDetail.Open;
    dsourceMaster.DataSet:=cdsMaster;
    dSourceDetail.DataSet:=cdsDetail;

    //cdsVentasDetalles.MasterSource := dsourceMaster;

    salesGrid.DataSource:=dsourceMaster;
    invDetails.DataSource:=dSourceDetail;


end;

hagsoft 22-02-2020 07:28:55

Me respondo yo mismo esta es la forma con lo que consegui si alguno le sirve. saludos.



Código Delphi [-]
procedure TfrmSellGrid.facturasMasterDetail;
var
  providerMaster:TDataSetProvider;
  cdsMaster,cdsDetail:TClientDataSet;
  dsRelacion,dsourceMaster,dSourceDetail:TDataSource;
  SQLQuery1, SQLQuery2:TUniQuery;

  dsfKey:TDataSetField;
begin
  providerMaster:=TDataSetProvider.Create(nil);
  cdsMaster:=TClientDataSet.Create(nil);
  cdsDetail:=TClientDataSet.Create(nil);
  dsRelacion:=TDataSource.Create(nil);
  dsourceMaster:=TDataSource.Create(nil);
  dSourceDetail:=TDataSource.Create(nil);
//  try

     SQLQuery1:=TUniQuery.Create(Self);
     SQLQuery2:=TUniQuery.Create(Self);
     SQLQuery2.Name:='SQLQuery2'; //Importante definir este campo en el query para lograr la relacion maestro detalle debe llevar el mismo nombre en el datasetfield.

     dsRelacion.DataSet:=SQLQuery1;
     SQLQuery2.MasterSource:=dsRelacion;

    with SQLQuery1 do
    begin
      Connection:=dm.dbaseConn;
      Close;
      SQL.Clear;
      SQL.Add('SELECT * FROM facturas ');
      Open;
    end;
    with SQLQuery2 do
    begin
      Connection:=dm.dbaseConn;
      Close;
      SQL.Clear;
      SQL.Add('SELECT * FROM facturas_detalles');
      SQL.Add('WHERE idFactura = :idFactura');
      //autoEdit:=True;
      //MasterSource:=dsRelacion;
      Open;
    end;

    //SQLQuery2.DataSource:=dsRelacion;
    //providerMaster.DataSet:=SQLQuery1;
    //cdsMaster.ProviderName:=providerMaster.Name;

    providerMaster.DataSet:=SQLQuery1;
    cdsMaster.SetProvider(providerMaster);

    with TIntegerField.Create(Self) do
    begin
      Name := 'idFactura';
      FieldKind := fkData;
      FieldName := 'idFactura';
      DataSet := cdsMaster;
      Required := True;
    end; //ID
     with TDateField.Create(Self) do
    begin
      Name := 'fecha';
      FieldKind := fkData;
      FieldName := 'fecha';
      DataSet := cdsMaster;
      Required := True;
    end; // campos......
    with TDataSetField.Create(Self) do
    begin
      Name := 'cdsMasterSQLQuery2';
      FieldKind:=fkData;
      FieldName := 'SQLQuery2'; //debe llevar el mismo nombre del query detalle.
      DataSet := cdsMaster;
    end;

    
    cdsDetail.DataSetField:=TDataSetField(FindComponent('cdsMasterSQLQuery2'));

    cdsMaster.Open;
  
    cdsDetail.Open;
    dsourceMaster.DataSet:=cdsMaster;
    dSourceDetail.DataSet:=cdsDetail;



    salesGrid.DataSource:=dsourceMaster;
    invDetails.DataSource:=dSourceDetail;


end;

ElKurgan 24-02-2020 07:42:27

Gracias por compartir la solución

Un saludo


La franja horaria es GMT +2. Ahora son las 01:11:10.

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