Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Coloboración Paypal con ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 29-06-2011
Ignacio Gentile Ignacio Gentile is offline
Miembro
NULL
 
Registrado: may 2011
Posts: 15
Poder: 0
Ignacio Gentile Va por buen camino
Chris aca te dejo el código completo de ese Procedimiento que dices..Los valores se cargan bien porque en el combo se desplega con todos los elementos que deberían aparecer, solo que al seleccionar uno de ellos (el index lo obtiene bien) el resultado es siempre el mismo objeto..

Código Delphi [-]
procedure TfrmElegirEmpresa.ListaEmpresa;
var nuevoItem,Item2:TEmpresa;
    bandera,i,j:integer;
begin 
      ZQuery1.Connection := frmTablas.ConnectionJHL;
      ZQuery1.SQL.Clear;
      ZQuery1.SQL.Text := 'select obtener_empresas (' + IntToStr(frmLogin.codigo_usuario) + ')' ;
      ZQuery1.Open;

      cmbEmpresa.Items.Clear;
      nuevoItem := TEmpresa.Create;
      frmTablas.tblEmpresa.First;
      for i:= 0 to frmTablas.tblEmpresa.RecordCount-1 do
        begin
          nuevoItem.id := frmTablas.tblEmpresa['cod_empresa'] ;
          nuevoItem.Descripcion := frmTablas.tblEmpresa['razon_social'];
          ZQuery1.First;
          for j:=0 to ZQuery1.RecordCount-1 do
          begin
             if (DBGrid1.Fields[0].Value = nuevoItem.id) then
              begin
                  cmbEmpresa.Items.AddObject(nuevoItem.Descripcion, nuevoItem);
              end;
             ZQuery1.Next
          end;
        frmTablas.tblEmpresa.Next;
        end;
end;
Responder Con Cita
  #2  
Antiguo 29-06-2011
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 24
Caro Va por buen camino
Hola Ignacio Gentile, tu codigo para añadir y recuperar objetos de tu ComboBox esta bien, el problema es que solo estas creando un objeto de TEmpresa (por eso solo se va modificando los valores que tiene y al final queda con los datos de tu ultimo registro, osea todos los items de tu combobox apuntan al mismo objeto), debes crear tus objetos de TEmpresa dentro del For.

Código Delphi [-]
     frmTablas.tblEmpresa.First;
      for i:= 0 to frmTablas.tblEmpresa.RecordCount-1 do
        begin
          nuevoItem := TEmpresa.Create;
          nuevoItem.id := frmTablas.tblEmpresa['cod_empresa'] ;
          .......................................................
          .......................................................
          .......................................................    
        end;

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.

Última edición por Caro fecha: 29-06-2011 a las 16:31:15.
Responder Con Cita
  #3  
Antiguo 29-06-2011
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 38
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 Ignacio.

Podrías cargar el ComboBox desde el procedimiento directamente con el query:
Código Delphi [-]
procedure TfrmElegirEmpresa.CargarEmpresas(AQuery: TZQuery; AComboBox:TComboBox);
begin
  AQuery1.Connection := frmTablas.ConnectionJHL;
  AQuery.SQL.Text:='SELECT * FROM TABLA_EMPRESAS';
  AQuery.Open;
  while not AQuery.Eof do
  begin
    AComboBox.Items.AddObject(AQuery.FieldByName('razon_social').AsString,
       TObject(AQuery.FieldByName('cod_empresa').AsInteger));
   AQuery.Next;
  end;
  AQuery.Close;
  AComboBox.Sorted:= True;
end;
Aquí ya tendrías cargado en el ComboBox la razón social y el código. (ordenado por razón social)



Luego para obtener el código de empresa sólo basta con hacer:
Código Delphi [-]
procedure TForm1.cmbEmpresaChange(Sender: TObject);
var
  cod: Integer;
begin
  cod:= Integer(cmbEmpresa.Items.Objects[cmbEmpresa.ItemIndex]);
  ShowMessage(IntToStr(cod));
  ...
end;
Si cod_empresa es de tipo string, tendrías que cambiar:
Código Delphi [-]
  TObject(AQuery.FieldByName('cod_empresa').AsInteger)
  // Por
  TObject(AQuery.FieldByName('cod_empresa').AsString)
Y en el evento cmbEmpresaChange, cambiar el tipo de la variable cod y quitar la conversion.


Saludos.
__________________
Daniel Didriksen

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

Última edición por ecfisa fecha: 29-06-2011 a las 17:47:52.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
filtrar elementos de base de datos en delphi mediante combobox carlossc90 Tablas planas 3 05-06-2008 22:21:10
Como Añadir elementos a un combobox sidneyb OOP 2 15-04-2008 18:20:31
Recuperar los elementos seleccionados del ComboBox (AJAX) tramjauer HTML, Javascript y otros 0 22-08-2007 13:38:00
Dos elementos en un ComboBox BuenaOnda Varios 7 16-01-2007 17:21:26
Odenar elementos combobox dvlt OOP 1 06-06-2006 16:51:57


La franja horaria es GMT +2. Ahora son las 09:44:27.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi