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 :

Sql dynamique : problème avec rowtype


Sujet :

PL/SQL Oracle

  1. #1
    Membre averti
    Inscrit en
    Mars 2006
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 30
    Par défaut Sql dynamique : problème avec rowtype
    J'essaie d'appeler une procédure stockée d'une base de données distante via le programme suivant :

    Le problème est que la variable v_card_number est une variable de type %ROWTYPE.

    Et le compilateur n'accepte pas. Ceci.




    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    v_link := 'LINKA';
    EXECUTE IMMEDIATE ' BEGIN DT_INSERTCARD@'||v_link||' (:1,:2,:3,:4,:5,:6,:7,:8,:9,:10,:11); END;'
    USING
    IN v_card_number,
    IN v_accounts_link,
    IN v_addresses_table,
    IN p_expiry_date,
    IN p_start_val_date,
    IN p_birth_date,
    IN p_encoded_name,
    IN p_embossed_name,
    IN p_first_name,
    IN p_family_name,
    IN p_action_code;
    Le problème qui s'affiche :
    PLS-00457: expressions have to be of SQL types
    J'ai cherché l'origine de l'erreur. j'ai trouvé :

    Cause:
    an expression of wrong type is in USING or dynamic RETURNING clause. In USING or dynamic RETURNING clause, an expression cannot be of non-SQL types such as BOOLEAN, INDEX TABLE, and record.

    Action:
    change the expression type to a SQL type.
    Est ce que je peux la même procédure via d'autre méthode dbms_sql ou autre? Si oui merci de m'aider.

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Si tu n'as qu'un dblink, tu peux créer un synonyme vers la procédure distante, et ne plus passer en execute immediate

  3. #3
    Membre averti
    Inscrit en
    Mars 2006
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 30
    Par défaut C'est pa ca
    Re bonjour,

    le pbm c'est que j'ai plusieurs dblink. Et le nom du dblink a appeler est un paramétre.

Discussions similaires

  1. [SQL Server] Problème avec un curseur ?
    Par evans dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 07/04/2006, 11h01
  2. [SQL Server]Problème avec une requête récursive
    Par evans dans le forum Langage SQL
    Réponses: 3
    Dernier message: 05/04/2006, 20h16
  3. [SQL Access] Problème avec Sum()
    Par badgam piero dans le forum Access
    Réponses: 5
    Dernier message: 12/12/2005, 16h00
  4. [SQL Server]Problème avec l'authentification SQL SERVER
    Par tidou dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 20/04/2005, 15h40
  5. Réponses: 4
    Dernier message: 30/01/2005, 14h23

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