FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
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.
|
#2
|
||||
|
||||
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 |
#3
|
||||
|
||||
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
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#4
|
||||
|
||||
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(); mySQLUpdateSQL1->ModifySQL->Add(AnsiString().sprintf("UPDATE \"actor\"" "SET first_name = :%s" "WHERE actor_id = :%s", EditName->Text, EditId->Text)); mySQLUpdateSQL1->ModifySQL->Clear(); El segundo modo que he intentado es este: Código:
if(DBGrid1->DataSource->DataSet->Active) DBGrid1->Columns->operator [](1)->Field->Text="CUBO"; Cita:
|
#5
|
||||
|
||||
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
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#6
|
||||
|
||||
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? |
#7
|
||||
|
||||
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
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#8
|
||||
|
||||
-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. |
#9
|
||||
|
||||
Hola aguml.
Usando Edits, básicamente las acciones son, Código PHP:
Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#10
|
||||
|
||||
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 ( Codigo mediumint(8) unsigned default null auto_increment, Articulo varchar(50) not null, Cantidad int(10) unsigned not null, Precio double unsigned not null, PRIMARY KEY (Codigo) ); Con este ultimo obtengo esto: Código:
+----------+-----------------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +----------+-----------------------+------+-----+---------+----------------+ | Codigo | mediumint(8) unsigned | NO | PRI | NULL | auto_increment | | Articulo | varchar(50) | NO | | NULL | | | Cantidad | int(10) unsigned | NO | | NULL | | | Precio | double unsigned | NO | | NULL | | +----------+-----------------------+------+-----+---------+----------------+ Código:
+----------+------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+------------+------+-----+---------+-------+ | Codigo | bigint(20) | NO | MUL | NULL | | | Articulo | char(50) | NO | | NULL | | | Cantidad | bigint(20) | NO | | NULL | | | Precio | double | NO | | NULL | | +----------+------------+------+-----+---------+-------+ |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Consulta con valores null | Luis M. | Firebird e Interbase | 15 | 11-03-2012 00:06:56 |
Como obtener valores de una consulta | Alexandro | SQL | 5 | 26-02-2009 22:21:22 |
Consulta de valores consecutivos | Guillermosalva | SQL | 5 | 27-07-2007 08:49:15 |
Consulta entre valores | rruffino | Conexión con bases de datos | 1 | 11-05-2007 03:25:34 |
Campos de consulta con valores NAN | ElDuc | SQL | 1 | 12-09-2005 10:28:59 |
|