Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   UDF y firebird 2.5 (https://www.clubdelphi.com/foros/showthread.php?t=69843)

ARPE 13-09-2010 18:53:27

UDF y firebird 2.5
 
Hola a tod@s, de repente me encuentro que ninguna udf me funciona al probar FB 2.5.
¿qué tengo mal aquí?

Código Delphi [-]
library UDF25;

uses
  ShareMem,
  uFunciones in 'uFunciones.pas';

{$R *.RES}

exports
  asPrueba;

begin
end.

unit uFunciones;

interface

  function asPrueba(Var N: double): Double; stdcall; export;

implementation

function asPrueba(Var N: Double): double; stdcall; export;
Begin
  Result := N;
end;

end.

Código SQL [-]
    Declare External Function asPrueba
    Double Precision
    Returns DOUBLE PRECISION BY value
    ENTRY_POINT 'asPrueba' MODULE_NAME 'UDF25';

Select asPrueba(5.2)
from tabla;

La librería bien compilada en la carpeta UDF de firebird. Si creo una función sin parámetros de entrada va bien, pero en el momento que le pongo un parámetro de entrada (y he probado de todo tipo y varias maneras) no le gusta a firebird.

gracias de antemano

guillotmarc 13-09-2010 19:32:21

Hola.

Ni idea sobre lo que te está fallando. Aunque para darte una alternativa, yo no utilizo UDF's, todas mis funciones las programo en procedimientos almacenados.

Por ejplo.

Código SQL [-]
SET TERM ^ ;

create procedure "asPrueba" (
    NUM numeric(15,2))
returns (
    RESULT numeric(15,2))
as
begin
  RESULT = NUM;
  suspend;
end
^

SET TERM ; ^

Ahora si quieres utilizar esta función en una consulta cualquiera, la puedes llamar como una subconsulta. Es decir:

Código SQL [-]
select  XXXX,
          (select RESULT from "asPrueba"(TABLA.CAMPO)) as IMPORTE
from TABLA

Gestionar tus funciones en procedimientos almacenados es más sencillo que hacerlo en librerías externas (es más sencillo hacer una instalación nueva, una restauración de un sistema, etc. ...). Y muy complejo tiene que ser el problema para que no lo puedas programar en T-SQL.

Saludos.

ARPE 14-09-2010 07:56:54

Hola y gracias por la respuesta.
En lo posible uso procedimientos almacenados pero hay una serie de funciones en las que no me quedó otra (algunas de ellas por diversas circunstancias).
Estoy sobre un XP profesional SP3, ¿tiene algo que ver?, ¿hace falta alguna librería nueva para el fb2.5 (Microsoft.VC80.CRT.manifest, vccrt8_Win32.msi)?

duilioisola 14-09-2010 13:25:15

Cuál es el error que te da?
- Error de permisos.
- Error de ejecución.
- No encuentra la UDF
- ...

ARPE 14-09-2010 13:59:00

Hola, ¡qué fallo!, no le gusta a firebird da pocas pistas ¿verdad?

Desde una consulta me dice esto:
Unsuccessful execution caused by a system error that precludes successful execution of subsequent statements.
Error writing data to the connection.



Desde la aplicación con IBO me dice esto:
Fallo al abrir "Tabla".
Objeto: tbTabla
SELECT ALL Tabla.*
FROM Tabla

ISC ERROR CODE:335544741

ISC ERROR MESSAGE:

connection lost to database

ARPE 15-09-2010 09:23:07

¡¡¡ Al fin !!!
Por lo visto FB 2.5 se ha vuelto más limpio y no le gusta "stdcall", las udf deben ser declaradas con "cdecl".
Opté por stdcall por esto:
"On Windows, the operating system APIs are stdcall and safecall. (Note that stdcall is more efficient than cdecl)."

Saludos

Casimiro Notevi 15-09-2010 10:50:58

Tengo entendido que con cdecl quien llama a la función es el encargado de "limpiar" la pila recogiendo los parámetros utilizados, en cambio, con stdcall el encargado de esta tarea es la propia función llamada.

Visto de esta forma, a mí me parece mejor cdecl.

ARPE 15-09-2010 11:28:45

Por eso decía que es más limpio, o lo limpia él o desconecta el servidor (con dos c******).
Saludos.

rastafarey 07-10-2010 05:51:21

Resp
 
Prueba cambiando stdcall por cdel. Esto se usa par ver como son pasado los parametros lle hacer de esto para que puedas enteneder cual clausula debes usar.


La franja horaria es GMT +2. Ahora son las 05:28:35.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi