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

 
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 21-02-2020
hagsoft hagsoft is offline
Miembro
 
Registrado: jul 2013
Posts: 11
Poder: 0
hagsoft Va por buen camino
Question 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;

Última edición por hagsoft fecha: 21-02-2020 a las 20:04:28. Razón: Titulo.
Responder Con Cita
 



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
ClientDataSet maestro&detalle error Renees Conexión con bases de datos 1 08-02-2018 00:26:00
Maestro Detalle con ClientDataset Filtrado Joser Varios 6 19-09-2012 18:53:54
Problema con relación maestro-detalle en ClientDataSet David Conexión con bases de datos 3 11-01-2008 11:02:59
Maestro Detalle con ClientDataSet sin Provider fufo_m Varios 0 12-10-2007 18:09:02
maestro-detalle, clientdataset,xml jmlifi Varios 0 05-01-2006 12:14:29


La franja horaria es GMT +2. Ahora son las 01:29:30.


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