Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-07-2011
Avatar de oscarac
[oscarac] oscarac is offline
Miembro Premium
 
Registrado: sep 2006
Ubicación: Lima - Perú
Posts: 2.010
Poder: 20
oscarac Va por buen camino
Campos Persistentes dinamicos

buenas noches...
tengo una consulta
como puedo hacer para que los campos de cualquier query se puedan crear dinamicamente..
me explico mejor con un ejemplo

tengo un componente TAdoquery, el cual uso para realizar 2 consultas, para generar un reporte

consulta 1
Código Delphi [-]
 
Select Campo1, Campo2, Campo3 from tabla
Consulta2
Código Delphi [-]
Select Campo1, Campo2, Campo3, Campo4 from tabla

en el componente yo tengo creado los 4 campos
pero cuando ejecuto la primera consulta, se borran el campo4 y no me deja generar el reporte

existe alguna funcion parecida al DBGrid1.Columns.RebuildColumns ??
__________________
Dulce Regalo que Satanas manda para mi.....
Responder Con Cita
  #2  
Antiguo 26-07-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
Cita:
como puedo hacer para que los campos de cualquier query se puedan crear dinamicamente
Hola oscarac.

Con un IBQuery podés crear los campos de este modo:
Código Delphi [-]
...
  private
    FDateField: TDateField;
  end;
...
implementation
...
// Agregar campo 
...
begin
  IBQuery1.Close;
  FDateField:= TDateField.Create(Self); // Crear
  FDateField.FieldName := 'FECHA';
  FDateField.Name := 'IBQuery1FECHA';
  FDateField.Index := IBQuery1.FieldCount;
  FDateField.DataSet := IBQuery1;
  IBQuery1.FieldDefs.UpDate; //Actualizar definición de campos
  IBQuery1.Open;
end;

// Eliminar campo 
...
begin
  IBQuery1.Close;
  FDateField.Free;  // Eliminar
  IBQuery1.FieldDefs.Update;  
  IBQuery1.Open;
end;
Supongo que tendría que funcionar igualmente con ADOQuery. Por supuesto tiene que corresponderse el tipo de campo especificado en la creación con el que se cargará de la tabla. Así como también el valor de FieldName.

Saludos.
__________________
Daniel Didriksen

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

Última edición por ecfisa fecha: 26-07-2011 a las 08:21:54.
Responder Con Cita
  #3  
Antiguo 27-07-2011
ASAPLTDA ASAPLTDA is offline
Miembro
 
Registrado: jun 2003
Ubicación: COLOMBIA-CALI
Posts: 639
Poder: 21
ASAPLTDA Va por buen camino
Smile hola

hola podrias crear el campo 4 en la primera consulta dinamicamente
Select Campo1, Campo2, Campo3, 0 campo4 from tabla


Cita:
Empezado por oscarac Ver Mensaje
buenas noches...
tengo una consulta
como puedo hacer para que los campos de cualquier query se puedan crear dinamicamente..
me explico mejor con un ejemplo

tengo un componente TAdoquery, el cual uso para realizar 2 consultas, para generar un reporte

consulta 1
Código Delphi [-]
 
Select Campo1, Campo2, Campo3 from tabla
Consulta2
Código Delphi [-]
Select Campo1, Campo2, Campo3, Campo4 from tabla

en el componente yo tengo creado los 4 campos
pero cuando ejecuto la primera consulta, se borran el campo4 y no me deja generar el reporte

existe alguna funcion parecida al DBGrid1.Columns.RebuildColumns ??
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
Como bloquear registros sin usar campos persistentes uper MS SQL Server 2 11-07-2007 18:10:06
Campos Dinamicos - SQL Viet SQL 7 06-11-2006 12:23:59
Fastreport - Campos Dínamicos isg Impresión 0 16-10-2006 09:39:15
Crear eventos en campos dinámicos altp OOP 9 02-01-2004 19:17:22
Añadir campos persistentes en tiempo ejecucion Firibiri Conexión con bases de datos 3 22-12-2003 11:43:08


La franja horaria es GMT +2. Ahora son las 05:10:24.


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