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 21-06-2011
EgyEgy EgyEgy is offline
Miembro
NULL
 
Registrado: jun 2011
Posts: 15
Poder: 0
EgyEgy Va por buen camino
DbGrid con un campo ajeno a la tabla

Necesito desplegar una columna en un DBgrid, pero esta no tiene asignado un campo de la tabla relacionada. Ademas dicha columna debe permitirme seleccionar uno de dos valores.

Ya utilice la propiedad PickList, pero no me despliega la lista cuando lo ejecuto, y tambien el valor de ButtonStyle es cbsAuto, sin tener el resultado que quiero.

¿alguien sabrá si puedo realizar esto con un dbgrid o algun otro componente?
Responder Con Cita
  #2  
Antiguo 21-06-2011
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
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 EgyEgy.

Para hacerlo con los componentes de Delphi, podes valerte de un TComboBox. Agregá un ComboBox y asigna sus items en diseño o como en el ejemplo por código.
Código Delphi [-]
procedure TForm1.FormCreate(Sender: TObject);
begin
  ComboBox1.Clear;
  ComboBox1.Items.Add('Opción uno');
  ComboBox1.Items.Add('Opción dos');
  //ComboBox1.Items.Add('Opcion tres');
  // ...
  ComboBox1.Color:= DBGrid1.Color;
  ComboBox1.Visible:= False;
end;

procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
  if (gdFocused in State)and(Column.FieldName = 'TuCampo') then
  begin
    ComboBox1.ItemIndex:= -1; // 0:muestra 1er item, 1: el 2do...
    ComboBox1.Left:= Rect.Left + TDBGrid(Sender).Left + 2;
    ComboBox1.Top:= Rect.Top + TDBGrid(Sender).Top +2;
    ComboBox1.Width:= Rect.Right - Rect.Left;
    ComboBox1.Height:= Rect.Bottom - Rect.Top;
    ComboBox1.Visible:= True;
  end
  else
    ComboBox1.Visible:= False;
end;

procedure TForm1.ComboBox1Change(Sender: TObject);
begin
  with DBGrid1.DataSource.DataSet do
  begin
    Edit;
    FieldByName('TuCampo').AsString:= ComboBox1.Text;
    Post; // si queres que se almacene aún sin movilizarte en el DBGrid
  end;
end;
...

Saludos.
__________________
Daniel Didriksen

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

Última edición por ecfisa fecha: 21-06-2011 a las 10:28:45.
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
enviar registros de una tabla a un campo de otra tabla a travez de ciclo IF en MYSQL CLUSTERBIT SQL 8 23-10-2008 15:50:03
Reconocimiento del trabajo ajeno seoane La Taberna 19 04-06-2007 11:24:54
Actualizar un campo de una tabla con datos que se encuentran en otra tabla Morphine SQL 4 15-12-2006 22:47:42
Pasar un campo calculado a un campo del mismo DbGrid maravert Conexión con bases de datos 3 12-05-2006 00:31:30
UPDATE de un campo dependiendo del valor de un campo de otra tabla Javi2 SQL 5 18-04-2005 16:35:05


La franja horaria es GMT +2. Ahora son las 02:37:32.


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