Club Delphi  
    Paypal   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 Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-10-2008
Angel Fernández Angel Fernández is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia - España
Posts: 141
Poder: 23
Angel Fernández Va por buen camino
También quisiera saber como clonar un IbDataSet

Reflotando este hilo de gluglu de hace ya más de un año, quisiera saber si lograste resolver el problema de la clonación y cómo lo hiciste porque yo ahora me encuentro en la misma situación.

En mi caso es un fibdataset pero supongo que será igual que un ibdataset. Quiero tener dos dbgrid que reciben datos de dos fibdataset distintos pero con el mismo sql, misma tabla,etc. Es decir el ds2 es un clon del ds1. Lo que quiero hacer es poder filtrar el ds2 de forma independiente al ds1 y así, en un dbgrid mostrar todos los datos de una consulta, y en el segundo dbgrid los datos filtrados.

Recorrer los datos del ds1 no me sirve por lentitud y asignar todas los propiedades del ds1 al ds2 incluída la consulta en sql y volverla a abrir es también muy lento.

¿Alguna solución?

Un saludo.
Responder Con Cita
  #2  
Antiguo 26-10-2008
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.610
Poder: 32
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
Respondiendo a Ángel. Yendo desde lo más básico, podrías averiguar si el componente FIBDataSet cuenta con un método llamado Clone, CloneCursor o algún otro por el estilo, como es el caso en ciertos tipos de componentes de acceso a datos, y entonces ver su ayuda y probarlo para ver si te funciona como esperas.

Ahora bien, si lo anterior no fuese factible y continuase tu justa indisposición a ejecutar de nuevo la consulta sobre el servidor con otro componente (por la lentitud que mencionas), existe la alternativa sugerida arriba por ramiretor de usar componentes TClientDataSet. Una de las ventajas de esta clase de objeto es que posee un método llamado AppendData con el cual puedes copiar el contenido de un conjunto de datos dentro de otro, sin tener que realizar ninguna nueva consulta al servidor ni recorrer manualmente cada uno de los registros originales.

Si lo analizas, hacer dos veces la consulta sobre el servidor es lo que más vale la pena tratar de evitar, pero el copiar las propiedades de un componente a otro puede que no pase de escribir unas cuantas líneas.

En caso de que aún esto último quisieras evitar, y trabajes con Delphi 7, podrías emplear la función ghCloneDataSet de GH Freebrary (sin pretender hacer spam). Esta función no clona los registros contenidos en el conjunto de datos, pero sí se encarga de crear un nuevo componente con todas y cada una de las propiedades y eventos establecidos en el original, además de sus parámetros e incluso campos persistentes que le hayas establecido en tiempo de diseño (con la opción de excluir algunos de estos elementos).

Código Delphi [-]
Uses
  GHFData;

// Ejemplo con TIBDataSet
procedure TForm1.Button1Click(Sender: TObject);
begin
  { Clonamos el conjunto de datos IBDataSet1, haciendo que el formulario
    sea el dueño del nuevo componente y asignando éste a DataSource2 }
  DataSource2.DataSet := ghCloneDataSet (IBDataSet1, Self, 'Active;Name');

  { Abrimos el conjunto de datos clon, apertura con la cual se ejecuta una
    consulta más sobre el servidor }
  DataSource2.DataSet.Open;
end;

// Ejemplo con TClientDataSet
procedure TForm1.Button2Click(Sender: TObject);
begin
  { Clonamos el conjunto de datos ClientDataSet1, haciendo que el
    formulario sea el dueño del nuevo componente y asignando éste a
    DataSource2 }
  DataSource2.DataSet := ghCloneDataSet (
    ClientDataSet1, Self, 'Active;Name');

  { Asignamos (agregamos) al conjunto de datos clon una copia de los
    registros actuales de ClientDataSet1 (sin necesidad de consultar al
    servidor nuevamente) }
  TClientDataSet (DataSource2.DataSet).AppendData (
    ClientDataSet1.Data, True);
end;

NOTA: Dependiendo de cuál sea el actual dueño del conjunto de datos a clonar, convendrá excluir del copiado a la propiedad Name, ya que no es posible tener dos componentes del mismo nombre conferidos al mismo dueño (propietario), a menos, claro, que la propiedad Name de éstos se deje vacía. (El ejemplo lo hice con los conjuntos de datos colocados dentro del formulario).

Un abrazo con copia.

Al.

Última edición por Al González fecha: 26-10-2008 a las 04:51:33.
Responder Con Cita
  #3  
Antiguo 26-10-2008
Avatar de RONPABLO
[RONPABLO] RONPABLO is offline
Miembro Premium
 
Registrado: oct 2004
Posts: 1.514
Poder: 23
RONPABLO Va por buen camino
Esto se me parece a una necesidad que tuve...
__________________
"Como pasa el tiempo..... ayer se escribe sin H y hoy con H"
Responder Con Cita
  #4  
Antiguo 26-10-2008
Angel Fernández Angel Fernández is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia - España
Posts: 141
Poder: 23
Angel Fernández Va por buen camino
Gracias por vuestra ayuda Ronpablo y Al. Como siempre, el maestro Al siempre da más de lo que uno podría esperar en este foro. Espero algún día saber la mitad que tú.

Un saludo.
Responder Con Cita
  #5  
Antiguo 27-10-2008
Angel Fernández Angel Fernández is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia - España
Posts: 141
Poder: 23
Angel Fernández Va por buen camino
Lo he resuelto con el componente kbmMemTable

He resuelto el problema con el componente kbmMemTable que es libre para uso no comercial.
Podéis bajarlo de http://www.components4programmers.co...able/index.htm

Se inserta un kbmMemtable y se le asignan las siguientes propiedades:

Código Delphi [-]
MemTable1.LoadFromDataSet(RxDBGrid1.DataSource.DataSet,mtcpoStructure,mtcpoOnlyActiveFields,mtcpoPro  perties,mtcpoLookup,mtcpoCalculated]);
MemTable1.Filter:='Sensor ='+quotedstr('tem025');
MemTable1.Filtered:=true;
MemTable1.Open;
MemTable1.Active:=True;

Luego conectamos un datasource al memtable1 y un dbgrid al datasource y listo.

No es la solución que me sugería Al González; es peor quizá porque implica el uso de componentes de terceros, pero cuando Al me contestó ya estaba casi resuelto y he querido dejar constancia de ello.

Espero le sirva a alguien.

Un saludo.
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
Duplicar / Clonar tabla con ADO Marcb3 Conexión con bases de datos 2 30-01-2007 13:15:37
Como Clonar un ibDataset???? AGAG4 Firebird e Interbase 4 28-10-2004 17:21:36
IBX TIBDataset ¿cómo lanzar las distintas sentencias en él? trastamara Firebird e Interbase 5 08-09-2004 00:36:14
Búsquedas y TIBDataSet Clantt Conexión con bases de datos 0 12-08-2004 01:01:07
Orden en TIBDataset barman Firebird e Interbase 6 24-11-2003 21:26:00


La franja horaria es GMT +2. Ahora son las 05:59:57.


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