Sentencia Update no se ejecuta en código Delphi
Otra vez molestando amigos, resulta que tengo un código que lo único que hace es generar la edad de un alumno y un update del campo EDAD, sin embargo al momento de ejecutarse se pasma y no modifica la tabla.
Se que tal vez esto ya lo hayan resuelto, pero estuve buscando y no se si por mi falta de conocimientos en el foro no encontré nada igual a este problema, agradezco su ayuda. Este es el código: (la variable txt_Query la separe muchas veces para verificar que no se me pasara ningún detallito)
Y esta es la función que realiza el update:
Se me olvidaba mencionar que uso paradox y delphi6... Saludos!!!! Pd. Quiero agradecer por el apoyo que me brindaron en mi anterior hilo, no se que pasa pero no puedo responder. |
Por favor, recuerda poner títulos descriptivos a tus preguntas, gracias.
No olvides nuestra guia de estilo. Estamos haciendo cambios en el sistema de email, es por lo que no habrás recibido respuesta a otros mensajes. Saludos. |
Hola.
Hay mucho que se puede optimizar de tu código como por ejemplo traer año, mes y día diréctamente desde la consulta, pero sería importante saber:
Otra cosa que no entiendo es el por que de armar la cadena de consulta de este modo: cuando es exáctamente lo mismo hacerlo así:
Saludos :) |
Ademas de lo que te dice Daniel, tampoco es necesario que interpretes la fecha de la manera que lo estas haciendo (copiando de a partes del string)
Una forma mucho mas elegante y efectiva de hacerlo:
Aunque evidentemente esto solamente te funcionará si el campo en cuestion es de tipo fecha Por otro lado
Dado que estas usando una sentencia de tipo SELECT no deberias estar usando ExecSQL, que se usa para ejecutar sentencias Insert, Update, Delete, etc Para Select deberias usar open Luego la linea
No hace nada, es simplemente una variable booleana, si no le asignas True o False lo que estas haciendo es "consultar su valor" por nada. Si tiene sentido hacer esto:
Por ultimo si bien lo que te comenta Daniel sobre como armar la cadena SQL
Es perfectamente valido, pero aun se podria mejorar utilizando parametros; lo ideal es usar parametros siempre que se pueda, aunque es cierto que hay ocasiones en las que al ir construyendo el string de forma dinamica no es tan sencillo hacerlo. Pero en tu caso que es un sql estatico es mejor usar parametros, asi:
|
Gracias, muchas gracias....
Gracias a todos por el apoyo, lamentablemente no funcionaron las soluciones que me recomendaron. Lo hice a manita por decirlo de alguna manera, buscando el registro y modificando el campo necesario. Seguramente el problema es mi delphi que es 6.0 (pirata) y mis tablas de fox 2.0.
Saludos y por aca andaremos dando lata... |
La franja horaria es GMT +2. Ahora son las 15:32:54. |
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