Précédent   Forum des professionnels en informatique > Bases de données > Firebird > SQL
SQL Forum d'entraide sur le SQL pour Firebird
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 03/02/2012, 15h19   #1
Inscrit
 
Inscription : mai 2004
Messages : 759
Détails du profil
Informations forums :
Inscription : mai 2004
Messages : 759
Points : 288
Points : 288
Par défaut Problème de création d'udf

Bonjour à tous

j'ai hésité un peu avant de poster ici, mais dans les cas je serai redirigé en fonction de vos conseils:
voici le code delphi de l'udf (code emprunter dans la faq):
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 
library Madll;
uses
  SysUtils,
  windows,
  Classes;
{$R *.res}
FUNCTION ib_util_malloc(l: integer): pointer; cdecl; external 'ib_util.dll';
FUNCTION ChangeMyString(const p: PChar): PChar; cdecl;
var
s: string;
begin
s := extractfilename(string(p));
Result := ib_util_malloc(Length(s) + 1);
StrPCopy(Result, s);
end;
begin
end.
Voici la déclaration dans firebird :
Code :
1
2
3
4
DECLARE EXTERNAL FUNCTION CHANGEMYSTRING
  CSTRING(255) CHARACTER SET ISO8859_1
RETURNS CSTRING(255) CHARACTER SET ISO8859_1 FREE_IT
ENTRY_POINT 'ChangeMyString' MODULE_NAME 'Madll.dll';
voici ma requête d'appel à l'UDF :
Code :
SELECT CHANGEMYSTRING(champ15) FROM MESINFORMATIONS
voici mon code d'erreur :
Citation:
Invalid token.
Invalid request BLR at offset 63.
Function CHANGEMYSTRING is not defined.
Module name or entrypoint could not be found.
j'ai mis ma dll dans le dossier UDF de firebird et j'ai rédémarer mon serveur !

ou ai je péché ?

Merci à tous
devalender est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/02/2012, 20h43   #2
Membre éprouvé
 
Avatar de JustMe
 
Inscription : juillet 2002
Messages : 432
Détails du profil
Informations forums :
Inscription : juillet 2002
Messages : 432
Points : 441
Points : 441
il te manque :

Code :
1
2
3
4
exports 
  ChangeMyString;
begin
end.

pour que ta fonction soit utilisable par les programmes appelant, sinon elle est local.
__________________
<On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**
http://www.mobile-tactile.com/
JustMe est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/02/2012, 10h46   #3
Inscrit
 
Inscription : mai 2004
Messages : 759
Détails du profil
Informations forums :
Inscription : mai 2004
Messages : 759
Points : 288
Points : 288
Effectivement ! merci
devalender est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h18.


 
 
 
 
Partenaires

Hébergement Web