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 Procédural MySQL Discussion :

[BDD] Comment Executer Une SP Mysql avec ADODB depuis PHP


Sujet :

SQL Procédural MySQL

  1. #1
    Membre à l'essai
    Inscrit en
    Mars 2006
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 13
    Points : 13
    Points
    13
    Par défaut [BDD] Comment Executer Une SP Mysql avec ADODB depuis PHP
    Bonjour,
    J'essai d'executer une Procédure Stockée Mysql depuis un script PHP au moyen d'une connexion ADODB et je n'y arrive pas.
    J'arrive parfaitement a exécuter une requete mais lorsque que je remplace la requete par un appel à une procédure le recordet est vide.
    Voici le code que j'utilise.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     
     $db = NewADOConnection('mysql');
     $db->Connect($hostname_bdf, $username_bdf, $password_bdf,   $database_bdf);
     
     $result = $db->Execute("call essaiADODB()");
     
     if ($result === false) die("failed");
    La page de retour renvoie failed donc mon recordset est vide.
    Pouvez vpus dire qu'elle est la syntaxe pour appeller une procédure stockée.
    Merci

    php -->V 5.1.1
    Mysql--> v5.0
    librairie PHP --> adodb.inc.php

  2. #2
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 101
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 101
    Points : 8 211
    Points
    8 211
    Billets dans le blog
    17
    Par défaut
    Pour avoir plus d'infos sur l'erreur essaie ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo $db->errorMsg( ) ;
    Pouvez vpus dire qu'elle est la syntaxe pour appeller une procédure stockée
    Si on s'en tient au SQL le CALL est correct http://dev.mysql.com/doc/refman/5.0/en/call.html
    Quel est le résultat si tu appelles ta procédure directement depuis le client MySQL en ligne de commandes ?
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

  3. #3
    Membre à l'essai
    Inscrit en
    Mars 2006
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 13
    Points : 13
    Points
    13
    Par défaut
    La procédure lance une requete select dont le résultat est d'une colonne sur plusieurs lignes.

    Voici le message d'erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    "PROCEDURE bdfdevinodb.essaiADODB can't return a result set in the given contextfailed"
    J'avais déjà eu ce pb auparavant il avait fallu recompiler avec Mysqli...et utiliser les functions mysqli depuis PHP.

    Le pb est que ns essayons d'utiliser la classe d'abstraction ADODB afin de rendre portable nos developpements pour un éventuel changement de SGBD.

    Mais j'ai lu que la limite de la portabilité de ADODB s'arretait justement aux procédures stockées alors je crois que ns allons oublier ADODB et poursuivre avec LES FUNCTIONS PHP mysqli..

    Par contre je suis quand même curieuse d'avoir la réponse quant à la syntaxe pour l'appel d'une SP MySQL avec ADODB ....
    si quelqu'un a la réponse...
    Merci

  4. #4
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 101
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 101
    Points : 8 211
    Points
    8 211
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par audreyc
    Le pb est que ns essayons d'utiliser la classe d'abstraction ADODB afin de rendre portable nos developpements pour un éventuel changement de SGBD
    Pourquoi ne pas utiliser l'extension PHP d'abstraction de BdD PDO ? http://www.php.net/pdo

    si quelqu'un a la réponse...
    Pas moi, désolé.
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

Discussions similaires

  1. Comment executer une requete json avec java?
    Par stpaul04 dans le forum Débuter avec Java
    Réponses: 7
    Dernier message: 03/08/2014, 04h27
  2. Réponses: 5
    Dernier message: 01/05/2013, 14h29
  3. [MySQL] connexion à une base Mysql avec ADODB
    Par vero12 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 09/09/2008, 11h07
  4. Réponses: 1
    Dernier message: 02/05/2006, 17h48
  5. Réponses: 3
    Dernier message: 06/01/2006, 08h57

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