Proc. almacenado como contador
Hola de nuevo, estoy trabajando con firebird y accedo mediante dbExpress en turbodelphi 2006, hice un procedimiento almacenado en el cual cuento la cantidad de registros de una tabla, y a este valor lo devuelvo en un parametro, en el modulo de datos utilizo un SQLStoredProc para utilizar el valor,
le asigne el procedimiento, le configure los parametros de entrada y salida pero cuando lo activo, propiedad active a true me da un error que dice: SQLSPcontador:Cursor not returned from query. Pero si fijo en la propiedad params[n].value me devuelve la cantidad de registros. Alguien puede ayudarme con este problemita o problemon, no lo se en realidad. Gracias Fede |
Cita:
Saludos |
Gracias Guti13, pero ya lo habia probado y nada. Lo que realice fue no activarlo, sino en runtime hacer SQLSPcontador.ExecProc, ya que este error se genera porque el Proc Almac no devuelve un set de registros, sino un valor en su parametro salida. Asi que está solucionado.
Fede |
Teóricamente, deberías eliminar el Suspend del SP y después ejecutar (ExecProc) el mismo. Básicamente es lo dicho por Guti13
Hay 2 tipos de procedimientos almacenados: - de selección - de ejecución La diferencia es conceptual: - Cuando devuelves un set de registros (SP de selección), debes utilizar Suspend dentro del SP y además abrirlo con .Open en delphi, además puedes usar una simple consulta (TQuery) con la instrucción:
- Cuando solo asignas un parámetro de salida, (SP de ejecución) no tiene sentido usar Suspend y además se ejecutará con ExecProc. Deberás usar un IBStoreProcedure o similar. Espero que haya aclarado algo. Saludos |
Gracias Lepe, estuvo muy bien tu aclaración, recien estoy aprendiendo con firebird y dbExpress y me vino muy bien.
Fede |
La franja horaria es GMT +2. Ahora son las 16:29:59. |
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