IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

SQL Firebird Discussion :

User Defined Function (UDF)


Sujet :

SQL Firebird

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    7
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 7
    Points : 11
    Points
    11
    Par défaut User Defined Function (UDF)
    Salut mes amis !

    Pouvez m'aider? J'ai conçu cette fonction en delphi que j'ai déclarée dans ma base de donnée. La fonction compilée dll est placé dans le répertoire UDF d'interBase. Mais quand je l'utilise par l'exemple dans une requête SELECT le résultat faux.
    Pouvez me proposer une autre?

    **********
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    library Farrondi;
    uses
      SysUtils,
      Classes;
     
    {$R *.RES}
    function Arrondi (Montant:double):integer; stdcall; export;
    begin
     Result:=Trunc(Montant);
    end;
     
    exports
      Arrondi;
    begin
    end.
    ************

    _______________________________
    - Balise Code rajouté par yobenzen

  2. #2
    Membre actif Avatar de TMuet
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Septembre 2003
    Messages
    225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 225
    Points : 288
    Points
    288
    Par défaut Re: User Defined Function (UDF)
    Citation Envoyé par mondelphi
    Mais quand je l'utilise par l'exemple dans une requête SELECT le résultat faux
    Mais encore
    Ton explication n'est pas très claire

    Ceci dit et même si je n'ai rien compris à ton problème, je peux déjà t'annoncer qu'il faut utiliser cdecl et pas stdcall

  3. #3
    Membre expert

    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Janvier 2004
    Messages
    2 123
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Responsable de service informatique

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 123
    Points : 3 256
    Points
    3 256
    Par défaut
    Salut

    Mais quand je l'utilise par l'exemple dans une requête SELECT le résultat faux.
    Quel est le résultat, en quoi est-il faux ? Messages d'erreur ?
    Peux-tu nous apporter quelques précisions afin de mieux pouvoir cerner le problème ?

    [Edit]TMuet m'a devancé ...

  4. #4
    Membre averti

    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    379
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 379
    Points : 376
    Points
    376
    Par défaut
    salut,

    ta reponse est fausse, car tu traite la valeur par valeur et pas par pointeur.

    or, il faut savoir que interbase utilise des pointeurs pour transmettre une valeur "float"

    il faut donc placer "var" devant la variable "Montant" pour régler le problème.

    je ne suis pas sûr, mais est ce que "stdcall" ne devrait pas être "cdecl" ou quelque chose comme cela?

Discussions similaires

  1. Comment retourner une table par UDF (user-defined function) ?
    Par brpat dans le forum SQL Procédural
    Réponses: 0
    Dernier message: 07/10/2009, 11h32
  2. [SQL2K] User defined function
    Par juelo dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 12/09/2007, 11h11
  3. [VB]user defined type undefined???
    Par Empty_body dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 13/02/2006, 14h36
  4. INSO Filter : "USER-defined exception" avec ctx_do
    Par Wiztiti dans le forum Oracle
    Réponses: 2
    Dernier message: 01/06/2004, 16h14
  5. USER DEFINE FONCTION : PB éxécution requête
    Par juelo dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 26/01/2004, 11h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo