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

PL/SQL Oracle Discussion :

Paramètre CLOB dans un appel d'une fonction C


Sujet :

PL/SQL Oracle

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 167
    Points : 69
    Points
    69
    Par défaut Paramètre CLOB dans un appel d'une fonction C
    Bonjour,

    En PL/SQL, j'ai déclaré l'appel à une fonction C ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    PROCEDURE DISC(param STRING, result OUT STRING, err_code OUT BINARY_INTEGER)
      AS LANGUAGE C
      NAME "disc"
      LIBRARY C_da
      PARAMETERS (
          param   STRING,
          result STRING,
          err_code INT);
    Je l'appelle depuis une autre procédure PL/SQL qui stocke le contenu de "result" dans une variable de type VARCHAR2.

    Mon problème c'est que j'ai un scénario où "result" à la sortie de la fonction C contient environ 90000 caractères.
    Du coup, la variable VARCHAR2 de ma procédure PL/SQL étant limitée à 32767 caractères, une exception est déclenchée.

    La solution est donc d'utiliser le type CLOB. Exact ?
    Si oui :
    - que devient la déclaration de ma fonction C en PL/SQL ?
    - comment écrire dans ma variable CLOB dans le code en C ?
    - comment lire correctement le résultat depuis mon code PL/SQL ?

    Merci d'avance.

  2. #2
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Si je ne m'abuse pas, pour utiliser le type Clob dans la procédure PL/SQL la procédure externe C devrait renvoyer un type OCILobLocator **. Autrement dite vous devez analyser les deux procédures: C et PL/SQL ensemble.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 167
    Points : 69
    Points
    69
    Par défaut
    C'est bien ce que je comptais faire : modifier la procédure C et PL/SQL.

    Je ne connais pas le type OCILobLocator.
    Comment manipuler ce type de variable en C et PL/SQL ?

  4. #4
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Regardez la doc PRO*C(C++) User Guide, vous allez trouver des exemples de manipulation des CLOB.

Discussions similaires

  1. Réponses: 34
    Dernier message: 27/08/2012, 13h01
  2. Réponses: 2
    Dernier message: 03/05/2007, 17h17
  3. [PHP-JS] Variable PHP comme argument dans l'appel d'une fonction Javascript
    Par The Molo dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 26/04/2007, 09h00
  4. pb dans l'appel d'une fonction
    Par badboys206s16 dans le forum ASP
    Réponses: 3
    Dernier message: 04/07/2006, 08h32
  5. Réponses: 2
    Dernier message: 09/01/2006, 09h38

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