FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Pasar registros de una DBGrid a otra Dbgrid usando multiselect
Buen día.
Necesito que me ayuden, necesito pasar los datos que tengo en una dbgrid, el usuario puede ir seleccionando los registros que desea pasar y cuando el lo desee ya sea por medio de un botón o el evento scroll dichos datos seleccionados se pasarán a otra dbgrid que esta abajo y de la primera Dbgrid los datos pasados a la segunda desaparecerán. De antemano muchas gracias. Última edición por Soa Pelaez fecha: 08-03-2017 a las 01:51:46. |
#2
|
||||
|
||||
En realidad mas que pasar registros de un DBGrid a otro, lo que queres hacer es copiar registros de un DataSet a otro. El DBGrid es una circustancia mas
La propiedad TDBGrid.SelectedRows contiene una lista de TBookmarks. Un TBookmark no es mas que un identificador, dentro de un TDataSet, de un registro, o si queres verlo de otra manera, es un identificador para cada fila de tu TDBGrid La clase TDataSet posee metodos para posicionarse de un TBookmark a otro, lo cual se explica aca. Basicamente lo que hay que hacer es llamar al metodo GotoBookmark. Aca hay un ejemplo La primer parte del problema ya la tendrias resuelta: recorrer las filas seleccionadas, posicionarse en cada una, y luego realizar la copia sobre el otro TDataSet Hay una seccion en la documentacion dedicada a esto: Copying Data from Another Dataset Tambien podes hacer la implementacion a lo "chapucero", es decir, si conoces la estructura del otro TDataSet, lo unico que hay que hacer es crear un nuevo registro en el DataSet destino (Append o Insert segun corresponda), setear los valores de los campos y luego invocar a Post Sino conoces la estructura del DataSet de antemano, o tenes que copiar todos los campos, se puede implementar un recorrido sobre los campos (Fields) de un DataSet e ir copiando el valor campo a campo. Obviamente que los campos deben estar en el mismo orden, con el mismo nombre y mismo tipo de datos Si no me equivoco puede que algunos componentes tengan implementado un metodo que hace justamente esto. por ej, FireDAC Por ultimo el codigo de estas unidades, si bien no hace exactamente lo que necesitas, te pueda servir como guia para armar tu solucion: https://github.com/ortuagustin/Delph...ee/master/Data Por ejemplo, este:
|
#3
|
||||
|
||||
Necesito que me ayuden, necesito pasar los datos que tengo en una dbgrid, el usuario puede ir seleccionando los registros que desea pasar y cuando el lo desee ya sea por medio de un botón o el evento scroll dichos datos seleccionados se pasarán a otra dbgrid que esta abajo y de la primera Dbgrid los datos pasados a la segunda desaparecerán o almenos validarlos para que no se dejen repetir en caso de que el usuario vuelva a seleccionar los mismos por equivocación.
De antemano muchas gracias. |
#4
|
||||
|
||||
No olvides nuestra guía de estilo, gracias
|
#5
|
||||
|
||||
Hola.
Otra opción:
llamada ej.:
Hace un tiempo se trató una variante aquí: Drag & Drop de una selección múltiple. Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 08-03-2017 a las 12:53:08. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Agregar registros a una tabla usando dbgrid | rufo | Conexión con bases de datos | 5 | 26-06-2015 18:10:40 |
Pasar de una Fila a Otra en Un DBGrid al Pulsar Enter | hondaalberto | Varios | 5 | 02-07-2012 19:59:40 |
Pasar registros desde un dbgrid a otro dbgrid con botones.. | Vales08 | Varios | 17 | 21-11-2011 19:27:50 |
Dbgrid y Multiselect | jorge_mosquera | OOP | 3 | 26-04-2007 03:22:41 |
qrInforme de registros seleccionados (dbgrid multiselect) | Mambo | Impresión | 2 | 07-12-2005 15:22:48 |
|