FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
Ultimo valor por Parámetro
Tengo un detalle, lo que pasa es que quiero que me regrese el ultimo valor de un campo entero con una sentencia SQL, lo que pasa es que por código me marca errores que no encuentra algun campo, siendo que existe fisicamente, ya lo hice por medio de un proc. almacenado el detalle es que tendria UN proc. almac. por cada Tabla y solo quiero aprovechar una utileria por todas las tablas... a continucion dejo el codigo de la sentencia...
Tabla.Active:=false; Tabla.SelectSQL.Clear; Tabla.SelectSQL.Add('SELECT Max('+Campo+')+1 FROM '+NombreTabla); //Me marca error al abrir la tabla, siendo que esta misma sentencia la tengo en el proc. almacenado Tabla.Active:=true; if not Tabla.IsEmpty then result:=Tabla.FieldByName(campo).Value; Tabla.Active:=false; |
#2
|
||||
|
||||
Bueno... fijate que hoy olvidé mi varita mágica, y por mas que he intentado concentrarme, no logro ver el mensaje de error que aparece en tu monitor. Quizas la frecuencia de actualización no esté dentro de mis parámetros.
Sería mucha molestia si haces favor de pegar el MENSAJE DE ERROR EXACTO que te aparece, y de ser posible, la CLASE DE LA EXCEPCIÓN que se eleva. Mil disculpas por la molestia... pero es que hoy mis poderes andan algo bajos. Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#3
|
||||
|
||||
Ok....
function DameUltimoRegistro(Tabla:tIBDataSet; Campo,NombreTabla:String):String;
var cadena:string; begin Tabla.Active:=false; Tabla.SelectSQL.Clear; Tabla.SelectSQL.Add('SELECT Max('+Campo+')+1 FROM '+NombreTabla); Tabla.Active:=true; if not Tabla.IsEmpty then result:=Tabla.FieldByName(campo).Value; Tabla.Active:=false; end; **Este es la funcion completa que tengo y el error este... Raised exception Class EDatabaseError with message 'bdCalcIva' :Field 'CalculoIva' No Found. Procees Stoped Lo raro que el campo que me señala si existe fisicamente, ya agregue los campos al dataset y me marca error en otro campo y asi se la pasa con otros campos, siendo que si existen en la base de datos FireBird 1.5 |
#4
|
||||
|
||||
Hola AGAG4.
Has intentado hacer una traza paso a paso de este procedimiento. Estoy casi seguro que la excepción se eleva en la línea result:=Tabla.FieldByName(campo).Value; Esto es porque, al hacer un
En ninguno de los motores que conozco el campo resultante se llamara "campo". Algunos le pondran Max(campo) otros, expr1, y asi. Estando seguro que es el único campo resultante de la consulta, creo que podes sustituir esa línea librememte por: result := Tabla.Fields[0].Value; o bien requerir explicitamente que el resultado se llame de la misma forma que el campo que estas sumarizando.
Por último, y esperando que el problema quede resuelto, te recomiendo aprender a usar las etiquetas [code], [delphi], [sql] y [php] que se hallan disponibles en los foros, para publicar trozos de código. Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#5
|
||||
|
||||
:(
Ya agregue lo que me dijo:
Tabla.SelectSQL.Add('SELECT Max('+Campo+')+1 as '+Campo+' FROM '+NombreTabla); pero de todas formas me marca el mismo error cuando activo(abrir) el dataset. No se que es lo que esta pasando siendo que la misma instruccion la hago dentro del IB Expert y si me corre el script. |
#6
|
||||
|
||||
Si estas usando dialecto 3, debes tener cuidado de que Campo esté declarado en mayúsculas en la tabla. Si las has creado visualmente con el IB-Expert, lo mas probable es que hayan quedado registrados con la combinación de mayúsculas y minúsculas usada durante la creación de la tabla.
Para salir de dudas, mejor encerrá el nombre del campo entre comillas dobles, con el case apropiado. En dialecto 3, no es lo mismo:
que
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
|
|
|