PDA

Ver la Versión Completa : duda edit, insert, delete en Delphi 7 y MySQL


eneseme
20-05-2010, 08:52:28
Saludos y gracias anticipadas por la ayuda.
LLevo mucho años con Delphi y Paradox, y multitud de aplicaciones, y he comenzado a efectuar una migración de Paradox a MySQL y al comenzar una serie de pruebas, me doy cuenta de lo siguiente, y no se si es desconocimiento o que ya no funcionan las cosas igual :
Hasta ahora usaba TTable y TDatasource para las tablas, y he instalado los
componentes Zeos, concretamente he probado TZTable.
no he modificado nada de codigo (de momento) y funcionan comandos tales como locate, etc, incluso puedes intercalar sentencias SQL.
el problema viene cuando quieres modificar un registro, por ejemplo

T_Clientes.Edit;
T_Clientes.FieldByName('Nombre').asstring := 'AAA';
T_Clientes.post;

ves el cambio reflejado el el dbgrid que tengo para ver los datos, que está asociado al Datasource de la tabla, pero si haces un close, y luego un open, los datos no quedan grabados, al igual que si haces un .delete, tampoco lo borra.
he probado con
T_Clientes.applyUpdates;
T_Clientes.CommitUpdates;
pero ni por esas.
seguramente no se puede, y ahora hay que trabajar con sentencias tipo select ... , update .... , insert ...., delete from .... en SQL.

alguien me puede dar un poco de luz sobre éste tema.
si es así, me veo obligado a modificar muchisimo código, cosa que haré, pero me gustaría no meter la pata.
al mismo tiempo, sabéis si existe algún libro en el mercado apropiado y con ejemplos Delphi - MySQL ?

Muchisimas gracias por la atención, y perdón por el tocho escrito.

Casimiro Notevi
20-05-2010, 10:47:41
Si haces post y commit, debería quedar grabado. Veamos qué opina otro compañero más experto en el tema.


p.d.: por favor, no repitas temas, gracias.

eneseme
20-05-2010, 11:57:25
tienes razón, creía que me había equivocado de sub-foro, y por eso lo puse en el otro. lo siento.
gracias

Casimiro Notevi
20-05-2010, 12:21:42
[..]
Hasta ahora usaba TTable y TDatasource para las tablas, y he instalado los
componentes Zeos, concretamente he probado TZTable.
no he modificado nada de codigo (de momento) y funcionan comandos tales como locate, etc, incluso puedes intercalar sentencias SQL.[..]

Me imagino que habrás cambiado los componentes que tenías antes por los de zeos. Por ejemplo, ese TTable lo has sustituido por el similar de zeos?

eneseme
20-05-2010, 12:28:29
pues sí, el TTable lo he sustituido por el TZTable, ya que el TTable no tiene como propiedad Connection, dentro de la cual, le pones la IP del servidor y el protocolo mysql-5.
hace la conexión perfectamente, incluso te muestra todos los campos del fichero en un dbgrid.
pero luego, el mantenimiento de datos, es lo que falla, no da errores ni nada,
simplemente no graba, no borra, etc.

Casimiro Notevi
20-05-2010, 12:48:44
¿Puedes poner algo de códgo más completo que lo anterior?

eneseme
20-05-2010, 13:02:25
Así funciona :

cod.Text := '7';
T_Est.locate('Cod',Vararrayof([Cod.text]),[loCaseInsensitive]);
Q_Est.SQL.Text := 'Update Estab set Nombre = "XXX" where Cod =' + cod.text;
Q_Est.ExecSQL;

// Ha Quedado modificado el registro
T_Est es un TZTable
Q_Est en un TZQuery

Así no funciona :
cod.Text := '7';
T_Est.locate('Cod',Vararrayof([Cod.text]),[loCaseInsensitive]);
T_Est.edit;
T_Est.FieldByName('DescExp').asstring := 'XXX';
T_Est.post;
T_Est.applyUpdates;
T_Est.Commitupdates;
// Cuando cierras la base, y luego la abres, no ha modificado el registro

Casimiro Notevi
20-05-2010, 13:20:37
No conozco bien los componentes zeos, pero creo que el commit debes hacerlo a la transaction de la conexión, sería algo así como:


ZTable1.Connection.Commit;


Así que en tu caso será:

T_Est.Connection.Commit;

eneseme
20-05-2010, 13:35:57
es curioso, haces la modificacion, ejecuto la sentencia que me indicas
t_estab.Connection.Commit;
en el dbgrid, se ve el campo modificado, sales y entras del programa,
y la modificación se ha perdido, está el valor anterior.
Parece ser que la modificación ha sido temporal, guardada en la caché.
como si faltase algún comando que fuerze la grabación en la base de datos.

eneseme
25-05-2010, 10:37:34
cod.Text := '7';
T_Est.locate('Cod',Vararrayof([Cod.text]),[loCaseInsensitive]);
T_Est.edit;
T_Est.FieldByName('DescExp').asstring := 'XXX';
T_Est.post;
T_Est.applyUpdates;
ConexionSQL01.AutoCommit := true;
ConexionSQL01.AutoCommit := false;

así queda grabado fisicamente, tambien se puede cambiar el .edit por .delete o por .append

saludos y gracias

Casimiro Notevi
25-05-2010, 11:52:39
ConexionSQL01.AutoCommit

Y si pones esta propiedad a true desde que inicias el programa, ¿funcionará siempre sin tener que poner true y luego false?

eneseme
25-05-2010, 12:03:21
tienes razón, lo tenia a false porque al principio, me lanzaba un error culpa mía por mezclar propiedades que no debía.
entonces quedaría así :


T_Estab.Edit;
T_Estab.FieldByName('DescExp').asstring := 'AAAAAA';
T_Estab.post;
T_Estab.applyUpdates;


(con conexion.autocommit := true en el diseño y conexion.loginprompt = false para que no pida contraseña)

saludos y mil gracias.