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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 17-08-2010
goduquez goduquez is offline
Miembro
 
Registrado: mar 2007
Posts: 24
Poder: 0
goduquez Va por buen camino
Pasar un registro dinámicamente

Hola amigos, llevo dias tratando de hacer un preocedimiento y no doy...
la pregunta es la siguiente.

1. la pregunta:
en un Tdataset puedo insertar un registro con:
Tdataset.InsertRecord([Dato1,Dato2,...]), bien este InsertRecord recibe un arreglo TVarRec, ¿como lleno un TVarRec para realizarlo de esta manera:
Tdataset.InsertRecord(variable)...?

2. el problema:
De una consulta SQL que hago en un query no sé cuantos campos tiene (Select * from ...) la idea es pasar esos datos a un TclienteDataset para realizar unos "manejos", ya puedo construir los campos en tiempo de ejecución en el clientedataset con los del query, pero no logro pasar los datos..pues no se cuantos campos tiene para hacer el InsertRecord(...:
seria como un metodo que me retornara ese arreglo de valores.

Por su atención muchas gracias.
Responder Con Cita
  #2  
Antiguo 17-08-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
¡Hola!

Podrías buscar o hacer una función que cree un arreglo dinámico de registros TVarRec a partir del registro actual de un conjunto de datos dado, pero creo que en tu caso hay otras opciones más directas:

Si el conjunto de datos cliente no tiene ya registros y no se le van a agregar de otras consultas, algo sencillo sería conectarlo con la consulta mediante un TDataSetProvider.

Otra solución es utilizar un ciclo For sobre los campos:

Código Delphi [-]
TablaDestino.Insert;

For I := 0 To TablaDestino.FieldCount - 1 Do
  CampoDestino [i].Assign (CampoOrigen [i]);

TablaDestino.Post;

Después de todo, se cumple el objetivo de pasar los datos, aunque para ello no hagas uso del método InsertRecord.

Saludos.

Al González.
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
Pasar al proximo registro del mismo campo con enter. mcasso Tablas planas 1 11-06-2010 20:04:09
Pasar Registro por Referencia NEG1414 C++ Builder 8 27-11-2009 07:58:08
pasar un registro de un dbedit a otro con el procedure edit betty_loo Conexión con bases de datos 1 07-11-2007 22:51:55
Como pasar datos entre dos formas modales creadas dinamicamente Tauro78 Varios 6 24-02-2007 15:03:39
insertar dinamicamente YolandaM Varios 4 16-03-2005 10:21:41


La franja horaria es GMT +2. Ahora son las 01:46:40.


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