FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
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. Última edición por nlsgarcia fecha: 14-07-2015 a las 02:06:47. Razón: Formateo Título |
#2
|
||||
|
||||
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. |
#3
|
||||
|
||||
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
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#4
|
||||
|
||||
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:
Última edición por AgustinOrtu fecha: 14-07-2015 a las 08:35:25. |
#5
|
||||
|
||||
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... |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Optimización de tiempo de ejecución de Update en Sentencia SQL | newtron | SQL | 26 | 24-09-2016 00:08:39 |
Crear una sentencia para update. | Adrian Murua | MySQL | 8 | 19-10-2012 08:38:16 |
Procedimiento Almacenado UPDATE no se ejecuta | Rockin | Firebird e Interbase | 25 | 25-05-2010 20:04:50 |
Sentencia UPDATE | kikecg | SQL | 5 | 16-10-2006 11:23:24 |
Como hago para colocar una sentencia sql en varias lineas de codigo en delphi | Shidalis | OOP | 5 | 16-08-2005 18:24:36 |
|