FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Pasar datos de un DBGrid a otro DBGrid
Hola, estoy usando Delphi y MySQL. Queria saber como puedo pasar los datos de un DBGrid a otro DBGrid.
Esta es la situación, tengo un form con: Edit1, Button1, Button2, DBGrid1, DBGrid2. El funcionamiento es el siguiente, en el Edit1 escribo una palabra presiono el Button1 y me trae todos los registros de la base de datos que están relacionados con esa palabra y los muestra en el DBGrid1(para esto uso DataSource1, ADOQuery1, ADOConnection1). Hasta aquí todo bien. El problema es como pasar los datos del DBGrid1 al DBGrid2, no quiero pasar todos, sino que el usuario seleccione un registro del DBGrid1 presione Button2 y el registro seleccionado pase al DBGrid2. Espero que puedan ayudarme, desde ya muchas gracias por su atención. |
#2
|
||||
|
||||
Hola lucas05.
¿ La tabla referenciada por ADOQuery1 es igual a la que se mostrará en DBGrid2 ? Es decir, ¿ A que TDataSource y TDataSet está conectado el DBGrid2 ? Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#3
|
|||
|
|||
Hola ecfisa, el DBGrid2 no lo conecte a ningun DataSource y tampoco a ningun ADOQuery.
Gracias por responder. |
#4
|
||||
|
||||
Hola Lucas.
Es que así no funciona la cosa... Simplificando mucho el concepto, un TDBGrid es la representacíón visual del valor de los campos de una tabla o consulta, no trabaja por sí sólo. No sé que deseas hacer con los campos del registro seleccionado en DBGrid1, en gran medida de eso depende que camino seguir. Un saludo.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#5
|
|||
|
|||
Hola ecfisa, nuevamente gracias. En otros temas del foro vi que hacían algo parecido, seleccionaban un registro de una grilla presionaban un button y pasaban los datos de ese registro a varios Edit.
Lo que intento hacer es lo mismo, pero en vez de pasar los datos a los Edit quiero pasar los datos a otra grilla. Osea volver a mostrar el mismo registro de la primera grilla en la segunda grilla, pero no todos los registros sino los que selecciono de la primera grilla Gracias por tu atención. |
#6
|
||||
|
||||
Cita:
Es decir que ClientDataSet1 tiene que tener una copia de todos los campos del ADOQuery1. Luego el código: Haciendo click sobre el TButton se irá copiando a DBGrid2 el registro que esté seleccionado en DBGrid1. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#7
|
||||
|
||||
Cita:
Creo que esta es la clave. Cita:
¿Y una vez que has pasado el registro al segundo DBGrid, qué vas a hacer con él? ¿Cerrarás el formulario y ya está? ¿Debe quedar constancia en algún sitio? ¿El usuario va a modificarlo y debe quedar guardado en Base de Datos? ¿Vas a generar un listado? .... ¿Qué pasa después cuando el usuario vea ese registro en el segundo DBGrid? Creo que eso es lo que estaba intentando preguntar ecfisa. Lo que vayas a hacer con esos datos es lo que determina la solución óptima.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#8
|
|||
|
|||
Hola Neftali, gracias por sumarte. Una vez que paso el o los registros a la segunda grilla (pueden ser uno o varios) lo que quiero hacer es sumar el campo "precio" (este campo tiene un valor numérico) de todos los registros que están en la segunda grilla. Y el valor de la suma guardarla en la base de datos.
Muchas Gracias. |
#9
|
||||
|
||||
Hola.
Si hiciste el código anterior, basta con que agregues esta función: Y cuando desees calcular los precios que estan en DBGrid2 solo tenés que llamarla. Ejemplo donde se muestra la sumatoria:
Del mismo modo podrías asignarlo a un campo de una tabla de tu bd, como por ejemplo:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#10
|
|||
|
|||
Hola ecfisa, gracias por tu aporte. Aplique tu código y funciona bien.
El único problemita es que cuando guardo el resultado de la suma en la base de datos lo guarda siempre en el mismo registro. Ejemplo: hago una suma y lo guarda en el registro 1, vuelvo a realizar otra suma y en vez de guardarlo en el registro 2, lo vuelve a guardar en el registro 1, o sea lo sobreescribe. Como puedo resolverlo. Nuevamente Gracias. |
#11
|
||||
|
||||
¿Pero donde guardas la suma?, ¿en cual de los DBGrid's?, en el 1º DBGrid o en el 2º DBGrid?, ¿Y porque quieres guardar la suma en la base de datos?, los más lógico es realizar una SQL y mostrarla, ¿Cuantas base de datos están implicadas?
Un saludo. Última edición por olbeup fecha: 26-11-2011 a las 22:32:09. Razón: Restificar |
#12
|
||||
|
||||
Cita:
Si no seleccionas previamente el registro donde se guardará la sumatoria, al usar Edit sin haber camibiado previamente el posicionamiento en la tabla, el último valor siempre sobreescribirá al anterior. Si lo que buscas es ir añadiendo nuevos registros con las sucesivas sumatrorias tendrías que usar el método Append o Insert. Reemplazando en el código anterior sería:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 27-11-2011 a las 00:03:38. |
#13
|
||||
|
||||
Cita:
Ves, yo en este caso, si los registros del segundo DBGrid no se van a guardar, sino que sólo vas a guardar la suma resultante, tal vez hubiera utilizado en el segundo un TStringGrid, con 1 o 2 campos significativos y el PRECIO.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#14
|
||||
|
||||
Bienvenido a clubdelphi, como siempre aconsejamos a los nuevos, no olvides leer nuestra guía de estilo, gracias por tu colaboración
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Pasar registros desde un dbgrid a otro dbgrid con botones.. | Vales08 | Varios | 17 | 21-11-2011 19:27:50 |
Pasar Datos De Dbgrid A Otro | Helg17 | Tablas planas | 7 | 27-03-2009 10:16:37 |
Pasar informacion de un dbgrid a otro | schaka | Conexión con bases de datos | 3 | 11-02-2008 10:15:32 |
Pasar lineas de in dbgrid a otro dbgrid | look | OOP | 3 | 21-09-2007 23:16:29 |
Como extraer datos de un DBgrid a otro DBgrid | mickey | Conexión con bases de datos | 13 | 29-01-2004 05:05:30 |
|