FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
ClientDataSet, como funciona?
Hola como estan? Bueno les quiero preguntar, encontre este componente y cree una tabla en memoria, mi pregunta es como se debe trabajar esta tabla? se debe trabajar como si fuese una tabla normal, o sea usar append, post, edit, last...etc;
Bueno una vez q cargo los datos a la tabla virtual, llega la hora de pasar los datos q tengo en memoria a la tabla para grabar en disco, esto se ase de con una asignacion directa, o se hace de otra forma? Ej: TProductoCod.asString:= TVirtualCod.asstring; Les cuento q lo intente, y se compila y se ejecuta todo lo mas bien, pero no me pasa los datos de la tabla virtual a la original, me inserta el registro nuevo pero me lo deja en blanco en la tabla original. Gracias! |
#2
|
|||
|
|||
hola, por que no enlazas directamente el clientdataset con la tabla ? lo puedes hacer mediante el tSimpleDataSet, el cual, realizas la consulta, puedes navegar, añadir, borrar, etc..., y hasta que tu no quieras no se aplican los cambios en la tabla. Para aplicar los cambios, lo haces mediante:
Para controlar los posibles errores, mira el evento de la tabla OnReconcileError Un saludo |
#3
|
||||
|
||||
Revisa el método ApplyUpdates de Tcliendataset. Con eso consigues "Volcar" todos los cambios a la tabla real.
__________________
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. |
#4
|
|||
|
|||
Hola, JoseGA, mira, quisera sacarme una duda, xq no logro volcar los datos a la tabla en mi disco, y quisiera saber q se coloca en esta en este parentesis:
(nErroresSoportados), q se coloca? la cantidad de errores -1,0 y 1 o va otra cosa? Y esta sentencia se la puedo aplicar a un evento onclick de un boton? Gracias! |
#5
|
||||
|
||||
Código:
MaxErrors indicates the maximum number of errors that the provider should allow before prematurely stopping the update operation. Set MaxErrors to –1 to indicate that there is no limit to the number of errors Si colocas -1, no parará "prematuramente" como dice la ayuda. Además la sentencia te devuelve el número de errores que se han producido. No quiere decir que los vayas a perder, sino que intetará hacer todas las operaciones aunque algunas entre medio vayan dando errores. Si colocas 0 al primer error se detendrá. No hay nada obligatorio, puedes colocar lo que quieras segun tus necesidades.
__________________
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. |
#6
|
|||
|
|||
ok, neftali...eso lo tengo mas o menos claro, lo q no puedo lograr entender, como mandar esos datos a la tabla q tengo en disco.
Leyendo esto y otras cosas pregunto si podria ser, algo asi? en el evento onclick de un boton, dale la instruccion tTabla.ApplyUpdates(1); tTabla, se refiere a la tabla del clientdataset o a la q vuelco los datos? y donde le indico a q tabla van dirigido los datos? Gracias otra vez! |
#7
|
||||
|
||||
El codigo que te dicen lo puedes poner en boton y al hacer el ApplyUpdate, se aceptan los cambios que has hecho sobre la tabla, siempre y cuando tu ClientDataSet esta enlazado a otro DataSet que hace referncia a tu tabla, ahora si te has creado una tabla en memoria directamente desde tu ClientDataSet, ya es otra cosa.
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#8
|
|||
|
|||
Hola caro, te cuento q lo q yo hice es una tabla en memoria directamente. Me podrias decir como es para hacer el update a la tabla.
Voy a chequear de asociar directamente la tabla al clientdataset, para ver si me deja hacer lo q yo quiero, despues te comento, estoy convencido de q no...pero bueno hay q probar! Por favore si me podes explicar como pasar lo datos de mi tabla de memoria a la otra tabla...seria un golazooooo! Gracias! |
#9
|
||||
|
||||
Si nos dices cuál es esa "otra tabla" llegaremos pronto a buen puerto. ¿Qué base de datos estás utilizando? ¿Qué componentes estás usando para acceder a las tablas de esa base de datos? Danos más información de cómo está estructurado tu programa.
Es probable que requieras usar un componente "proveedor", TDataSetProvider, para ser más preciso. El cual sirve como enlace entre un componente "data set" cualquiera (un TTable, por ejemplo) y un TClientDataSet. Esperamos tu respuesta. Saludos. Al González. |
#10
|
||||
|
||||
Hola Pollo2004, como te dice el amigo Al, danos mas datos sobre tu programa.
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#11
|
|||
|
|||
Info solicitada
Les cuento q estoy usando las tablas paradox, para acceder a mis tablas y uso los componentes de la BDE, (TTABLE, bueno y el datasource para elazar con los componentes visuales).
Mi tabla es del estilo detalle de factura, en la cual busco cargar los datos de los productos de otra tabla, q eso lo eh logrado con el TClientDataSet, para despues ir calculando los totales y mejor control de los datos q ingreso a la factura para luego volcar en mis tablas las modificaciones q sufrio cada dato. Cualquier duda, por favor avisar! Necesito solucionar con urgencia este tema! Mil Gracias!!! |
#12
|
|||
|
|||
Resuelto...a medias!!!
Bueno probando y trantando de entender la ayuda con mi escaso ingles y google traductos, he avanzado en el tema y ya puedo cargar los datos en el clientdataset, hacer el calculo, bueno pero a la hora de usar el applyupdate (), me sale un error como q me falta dato, para ser mas preciso este es el error
ClientDataset1: Missing data provider or data package! No logro detectar el error, si alguien sabe a q se debe esto!! Gracias!!! |
#13
|
||||
|
||||
Hola Pollo2004, lo siento se me ha ido de tu hilo.
Estas dando datos a medias, nose por cual de las dos formas has hecho. Con el ClientDataSet puedes crear directamente una tabla en memoría, tu te creas la estructura de tabla en el ClientDataSet y para crear la tabla click derecho, seleccionas Create DataSet y desde ahí lo tratas como otro DataSet, añades registros modificas y eliminas, antes debes indicarle en que formato quieres guardar la tabla XML o Binario. Ahora también puedes tener registros o campos en memoría lo que a ti te interesa son los registros por lo que te entiendo. En ese caso primero necesitas un dataSet que estara relacionado con tabla, digamos un Table1, necesitas un proveedor DataSetProvider y un ClientDataSet, esta sería la relación. DataSource -> DataSet -> ClientDataSet1 ClientDataSet1 -> ProviderName -> DataSetProvider1 DataSetProvider1 -> DataSet -> Table1 cuando hagas digamos la inserción, lo haces sobre el ClientDataSet, donde estos registros no se van a registrar en la tabla fisica hasta que no hagas el ApplyUpdates. Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#14
|
||||
|
||||
Pues yo te iba a comentar lo mismo que Caro. No acabas de explicar (o yo no acabo de entender bien) como estás haciendo las cosas. Deberías explicar cómo tienes conectados y no estaría mal que explicaras cómo estás cargando los datos.
¿Si para cargar los datos has usado el "provider", cómo puede ser que no lo tengas en el AppllyUpdates? ¿No lo has usado? ¿Lo has desasignado?
__________________
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. |
#15
|
|||
|
|||
Explicacion...
Bueno ante todo gracias por responder....les cuento:
Primero hice como dijo Caro una tabla completamente en memoria, Tclientdataset, boton derecho create, luego le genere los campos q yo considere necesarios, hasta ahi todo ok. Luego el problema estaba en q no podia volcar esos datos en la tabla fisica (tablas en formato paradox), y como no logre encontrar el metodo para hacer este proceso (una lastima xq esataria bueno saber este tema) entonces decidi ir por otro lado... Asocie directamente mi clientdataset a un TTable, despues de varias horas logre cargar los campos de la tabla q precisaba, lo hice funcionar como yo queria pero a la hora de hacer el applyupdate (x) me salta el error q comente en el post anterior. (ClientDataset: Missing data provider or data package). Lo hice de esta manera....Tclientdataset-->boton derecho-->assing local data--> ahi lo asocio con mi tabla fisica (ttable de la BDE)--> y cargo los campos de la tabla, tambien genere alguno para buscar (loockup) y otro para calcular. luego le doy run...y la carga de los datos en el clientdataset lo hago de maravillas, el error salta a la hora de q le doy click a un boton q le asigne el applyupdate () del clientdataset. Primero probe con esa instruccion sola, y sale el error, luego al mismo boton y antes de hacer el update le coloquer la instruccion TTable.append (esta es la tabla asociada al clientdataset) y me sale lo mismo. Por lo q leo de la respuesta de CAro me estaria faltando un Datasetprovider, q no lo tenia y no sabia q se usaba. Me podrian explicar como funcionaria y si realmente lo necesito. Otra vez, Muchas gracias! |
#16
|
||||
|
||||
He subido un ejemplo sencillo aquí; A ver si eso te aclara las cosas. Está con BDE + TClientDataset; Cómo cargar los datos, modificarlos en memoria y volcarlos de nuevo.
__________________
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. |
#17
|
||||
|
||||
Cita:
Cita:
Cita:
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#18
|
|||
|
|||
Hola CARO y NEFTALI, bueno primero me he bajado el ej de NEFTALI y me aclaro muchas cosas, q ahora estoy implementando en mi proyecto, q le estoy buscando la vuelta para q funcione como yo quiero.
Bueno mi pregunta es en base a lo q dijo caro sobre recorrer la tabla de memoria e ir insertando los registros en la tabla fisica.... Esta idea seria algo asi? Ej: TMemoria.first; while not TMemoria.eof do begin TTable.append; TTableCampo1.asstring:= TMemoriaCampo1.asstring; TTableCampo2.asstring:= TMemoriaCampo2.asinteger; " " TMemoria.next; end; Gracias otra vez, y espero su correcion! |
#19
|
||||
|
||||
Cita:
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
Herramientas | Buscar en Tema |
Desplegado | |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
ClientdataSet como saber si esta abierto? | Coco_jac | Varios | 4 | 13-04-2012 19:36:43 |
¿como se utiliza un ClientDataSet? | Nelly | Varios | 5 | 06-06-2006 08:51:01 |
ClientDataSet Maestro Detalle como los relaciono | ASAPLTDA | Conexión con bases de datos | 1 | 29-01-2005 23:07:48 |
Como refrescar un ClientDataSet | Oxa78 | Providers | 8 | 25-08-2004 00:52:39 |
DBF Como funciona? | Descendents | Conexión con bases de datos | 1 | 15-07-2003 22:39:00 |
|