Actualizar valores desde una consulta
Hola amigos, tengo un formulario de c++Builder donde he colocado los siguientes componentes: mysqlquery, dbgrid, mysqldatabase, datasource (creo que esos eran los nombres) he conseguido conectar todo y que haga una consulta con el mysqlquery y que me lo muestre en el dbgrid. Hasta ahí todo bien. El caso es que no se si puedo hacer que al modificar algo en el dbgrid se actualice en la base de datos. ¿alguien sabe? Estoy usando dac for mysql.
|
Dependerá un poco de los componentes en sí y de la consulta que hagas. Una consulta del tipo
normalmente será actualizable (*). Esto quiere decir que bastará con que hagas el POST para que los cambios del DBGrid se reflejen en la base. El POST lo puedes hacer explícitamente, llamando al método correspondiente de mysqlquery, o implícitamente al momento de cambiarte de registro. Si la consulta involucra enlaces a otras tablas (JOINs) entonces es posible que no puedas actualizar los datos de foma tan sencilla pues el componente necesita saber exactamente a qué registro de qué tabla pertenece el campo modificado. Algunos conjuntos de componentes permiten especificar (en un componete auxilar o una propiedad) la consulta SQL necearia paa actualizar. En otros casos, tendrás que armar tú mismo la consulta UPDATE. ---------------------------- (*) Siempre y cuando columnas incluya una llave única de la tabla. // Saludos |
Hola aguml.
No he usado los componentes Microolap DAC for MySQL, pero por lo que pude mirar en la ayuda, son muy similares en el uso a los demás. Siendo así, deberías asociar al TMySQLQuery un TMySQLUpdateSQL para poder realizar consultas actualizables. Otra opción sería que optaras por usar el componente TMySQLDataset. Saludos :) |
He probado de dos maneras.
He colocado un componente TMySQLUpdateSQL y en el TMySQLQuery he puesto a este en la propiedad oportuna, luego en un botón hago esto: Código:
mySQLUpdateSQL1->ModifySQL->Clear(); El segundo modo que he intentado es este: Código:
if(DBGrid1->DataSource->DataSet->Active) Cita:
|
Hola aguml.
Para el primer caso tendrías que asociar el TMySQLUpdateSQL mediante la propiedad UpdateObject del TMySQLQuery y luego configurar en el primero las propiedades: DeleteSQL, InsertSQL y ModifySQL (al menos en los componentes como TUpdateSQL y TIBUpdateSQL funciona de ese modo). En el segundo caso, el mensaje de error lo está indicando. Tenes que poner el DataSet en modo edición o inserción antes de intentar la actualización: Código PHP:
Saludos :) |
Gracias amigo, ya he conseguido insertar, modificar, y eliminar de la base de datos pero ahora tengo otras dudas. Para eliminar o insertar una fila no tengo que ponerlo en modo Edit o Insert, para modificar si ¿a caso al eliminar o insertar una fila no estoy modificando la base de datos? es mas, si hago uso de Post() despues de insertar me guarda los cambios y sin el no me los guarda pero si lo uso despues de eliminar una fila me tira el error de que tengo que ponerla en Edit o Insert pero la fila ya aparece borrada permanentemente. Supongo que será algo que el creador de este componente ha querido hacer asi.
Otra duda, cuando elimino filas el indice es autonumerico y no queda correlativo ¿como puedo hacer que quede correlativo? Y la última, me gustaria que el indice apareciera con el formato "00000000" pero es un entero y no muestra los ceros a la izquierda ¿Se puede hacer lo que deseo? |
Hola aguml.
¿ Que componentes data-aware estas usando ? (DBGrid, DBEdit, etc.) ¿ Como estás realizando el borrado, inserción y modificacion ? ¿ Como y donde confirmas la acción realizada ? Saludos :) |
-Uso TEdits y DBGrid.
-El codigo que añade, edita, inserta, y elimina es este: Código PHP:
-Y confirmar no confirmo nada porque no se como se haria. Otra cosa mas, todo esto está muy bien pero si yo crease una aplicacion que usase esta base de datos ¿como haria para que al instalar otra persona en su pc mi aplicacion ya leyese la misma base de datos? En este caso me basta con que me la cree con la tabla que tengo y las columnas que tiene la tabla pero me interesa saberlo ya que he leido que no es como con SQLite, que yo cogia el archivo de la base de datos y lo colocaba junto con la dll y mi aplicacion y a tirar. He leido que no es un archivo, es mas, he mirado en las rutas que proponen por internet y el archivo no aparece, ni siquiera aparece nada con el nombre de la tabla o base de datos. Entonces me interesaria saber como mudar la base de datos de un pc a otro y como crear con estos componentes una base de datos y una tabla ya que lo tuve que hacer desde la consola usando comandos de mysql porque no vi la manera de hacerlo desde los componentes. |
Hola aguml.
Usando Edits, básicamente las acciones son, Código PHP:
Saludos :) |
Tanto con los botones y codigos que me indicas como con el DBNavigator da error. Dice algo asi como que no hay stament dataset o algo asi era. Por eso lo hice yo de esa manera.
Otra cosa, aun no se como crear la base de datos en runtime pero teniendo la base de datos creada si he podido ver como crear la tabla. Uso este codigo: Código PHP:
Código:
CREATE TABLE IF NOT EXISTS Productos ( Con este ultimo obtengo esto: Código:
+----------+-----------------------+------+-----+---------+----------------+ Código:
+----------+------------+------+-----+---------+-------+ |
La franja horaria es GMT +2. Ahora son las 12:34:45. |
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