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

Oracle Discussion :

Comment appeler une PROCEDURE STOCKé, Fonction et procédure ORACLE en JAVASCRIPT par ODBC


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2013
    Messages : 4
    Par défaut Comment appeler une PROCEDURE STOCKé, Fonction et procédure ORACLE en JAVASCRIPT par ODBC
    Bonjour,

    Je voudrais coder un appel de procédure, package, fonction Oracle en Javascript. J'ai un début de code mais cela ne fonctionne pas ! Je cherche la syntaxe exacte. Merci de votre aide !!!

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    <html>
    <head>
    </head>
    <SCRIPT LANGUAGE=javascript>
    <!--
    function ConSP()
    {
     
    var conn = new ActiveXObject("ADODB.Connection") ;
    var connectionstring="Provider=OraOLEDB.Oracle;User ID=USER;Password=PWD;Data Source=BASE;"
    conn.Open(connectionstring);
    var rs = new ActiveXObject("ADODB.Recordset");
     
    var p_out;
    rs.open("execute NOM_PACKAGE.NOM_FONCTION('TATA', :p_out);", conn); 
     
    rs.MoveFirst;
    while(!rs.eof)
    {
       document.write(rs.fields(0));
       document.write("</br>");
       rs.movenext;
    }
    // document.write(rs(0));
    rs.close;
    conn.close; 
    } //-->
    </SCRIPT>
     
    <body bgcolor="white" OnLoad="javascript:ConSP()"></body>
    </html>

    Bonne journée

  2. #2
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2015
    Messages : 38
    Par défaut
    Vous n'utilisez pas la bonne façon de faire.
    C'est très peu et pas du tout recommandé ce que vous faite.

    Utilisez plutôt NodeJS, il y a tout ce qu'il vous fait pour aller lire du oracle/mysql/MSsql.

    si toute fois ce n'est pas important pour vous, vous pouvez tenter une chance en modifiant votre connectionstring en incluant un Data Source du style

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var connectionString = "Provider=OraOLEDB.Oracle;Data Source=(DESCRIPTION=(CID=GTU_APP)(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=your_ip_address)(PORT=your_port)))(CONNECT_DATA=(SID=your_sid)(SERVER=DEDICATED)));User Id=your_uid;Password=your_pwd;"

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2013
    Messages : 4
    Par défaut
    bonjour
    merci de l'aide, mais l'erreur se trouve plutôt au niveau de la syntaxe du rs.open ...........
    La connexion à la base de données est OK, car quand je fais un simple select, cela fonctionne impec...
    C'est la syntaxe de l'appel de la fonction Oracle qui me pose souci !
    Merci de l'aide de tous

  4. #4
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2015
    Messages : 38
    Par défaut
    ok, alors faite quelque chose plus similaire à ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    rs.open("execute NOM_PACKAGE.NOM_FONCTION('TATA', "+p_out+");", conn);
    p_out est une variable javascript,

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2013
    Messages : 4
    Par défaut
    Merci de l'aide mais j'avais déjà testé cette syntaxe :
    voila le message d'erreur :
    ORA-00900 : invalid SQL statement

    pourtant sous sql developper, aucun souci, la procédure fonctionne nickel !!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    DECLARE
      P_IN VARCHAR2(200);
      P_OUT VARCHAR2(200);
    BEGIN
      P_IN := 'TEST';
     
      PACKAGE_NAME.PROCEDURE(
        P_IN => P_IN,
        P_OUT => P_OUT
      );
      :P_OUT := P_OUT;
    END;
    Merci pour d'autres réponses qui sont la bienvenue car je sèche grave !

  6. #6
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2015
    Messages : 38
    Par défaut
    p_out c'est vos données de sortie?? Alors c'est normal que ça ne fonctionne pas de cette façon.
    Désolé, je n'ai pas été vite. Alors là, peut-être que quelqu'un d'autres aura la réponse, je suis plus un fervant de NodeJS avec npn pour rouler mes requêtes Javascript et Oracle.

Discussions similaires

  1. comment appeler la procedure Stockeé sp_graintlogin?
    Par PDelph7 dans le forum Bases de données
    Réponses: 2
    Dernier message: 31/01/2007, 10h31
  2. comment Executer une procedure stocké paramétré
    Par Khalid.bounouader dans le forum Accès aux données
    Réponses: 1
    Dernier message: 30/10/2006, 17h36
  3. Réponses: 2
    Dernier message: 22/06/2006, 11h26
  4. [C#] Comment appeler une procédure stockée avec multiple SELECT ?
    Par Piolet dans le forum Accès aux données
    Réponses: 2
    Dernier message: 08/06/2006, 16h04
  5. Réponses: 3
    Dernier message: 26/01/2006, 10h55

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