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

PHP & Base de données Discussion :

PDO & MS SQL récupération d'un paramètre de sortie d'une procédure stockée [PDO]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Consultant Technique
    Inscrit en
    Janvier 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant Technique
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2012
    Messages : 6
    Points : 6
    Points
    6
    Par défaut PDO & MS SQL récupération d'un paramètre de sortie d'une procédure stockée
    Bonjour tout le monde,

    J'aurais besoin de vôtre aide, si vous le voulez bien, pour élucider mon mystère:

    J'ai une procédure stocker simple avec un paramètre en sortie dans ma base de données SQL SERVER
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    DROP PROCEDURE [dbo].[PROC_TEST] 
    GO
    CREATE PROCEDURE [dbo].[PROC_TEST]	@pProfile nvarchar(30) OUTPUT
    AS
    BEGIN
    	SET @pProfile	= 'profile'
    END

    Je cherche l’exécuter dans mon programme en php et récupérer donc la variable, je le fait de cette manière:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <?php
    	require_once '_db.php';
     
    	$stmt = $db->prepare('CALL PROC_TEST(?)');
     
    	$stmt->bindParam(1, $value, PDO::PARAM_STR, 30);
    	$stmt->execute();
     
    	echo "value contient :".$value; //Résultat attendue: "value contient :profile";
    ?>
    Et c'est là que ça coince, en sortie, à la place d'un jolie "profile" voici ce que j'obtient:
    value contient :½uteôM)@½ption½€½ption½

    Alors je me doute qu'il y a quelque chose qui ne vas pas dans mon code pourtant pas bien épais mais quoi?
    J'ai essayé plusieurs choses que j'ai trouvé dans divers forum:
    • $stmt->nextRowset();
    • $out = $stmt->fetch();
    • Faire un EXEC ou EXECUTE à la place de CALL
    • Mettre OUTPUT à côté du paramètre


    Mais rien ne fonctionne j'ai un résultat à peu près toujours différent mais tout aussi bizarre avec des caractères spéciaux.

    Je vous remercie d'avance et je m'en remets à vous.

  2. #2
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Essaye ceci pour voir :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     
    BEGIN
    	SELECT @pProfile = 'profile'
    END

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Consultant Technique
    Inscrit en
    Janvier 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant Technique
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2012
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Merci pour la réponse, j'ai fais le test c'est identique.

    Pour info au cas où je n'ai pas été claire, la procédure stocké fonctionne, je ne pense pas que ce sois elle le problème mais plus le code PHP. En base de données j'arrive correctement à lancer ma procédure et récupérer mon paramètre correctement.

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DECLARE @value nvarchar(30)
    BEGIN
    	EXEC PROC_TEST	@value output
     
    	PRINT @value -- J'ai bien la valeur "profile" en sortie
    END

  4. #4
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Fais un var_dump($value) pour voir exactement ce qu'il retourne.

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Consultant Technique
    Inscrit en
    Janvier 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant Technique
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2012
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Bonjour,

    j'ai finalement fait autrement, je renseigne une table dans la procédure et je l'interroge par la suite au lieu de récupérer des paramètres de sortie.

    Merci MaitrePylos pour tes réponses

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 10/11/2009, 09h30
  2. Réponses: 1
    Dernier message: 27/08/2007, 17h40
  3. Passer en paramétre un tableau dans une procédure stockée
    Par killysui dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 26/04/2006, 11h47
  4. Réponses: 2
    Dernier message: 19/03/2005, 17h09
  5. Récupération des paramètres en sortie d'1 procédure stockée
    Par navis84 dans le forum Bases de données
    Réponses: 1
    Dernier message: 23/12/2004, 11h40

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