Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PDO
PDO Forum d'entraide sur PDO (PHP Data Objects) : pilote générique de bases de données avec PHP. Avant de poster -> FAQ PDO et Cours PDO
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 03/01/2008, 14h28   #1
Invité régulier
 
Inscription : mars 2007
Messages : 48
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 48
Points : 8
Points : 8
Par défaut Les procédure stockées

bonjour
j'essaie d'appeler une procédure stockée avec un paramètre soit en entrée ou en sortie, n'importe.
J'ai réussi à appeler une procédure stockée qui ne copie pas de valeur mais quand il y a paramètre je n'ai pas le lien entre variable PHP et Mysql
Voici mes codes :

Pour un paramètre en entrée :
Code SQL :
1
2
3
4
5
6
CREATE PROCEDURE `bdtest`.`paraEntree` ( nb varchar(20))
BEGIN
 
INSERT INTO tabletest VALUES(NULL,nb);
 
END
Ou pour sortie :
Code SQL :
1
2
3
4
5
6
CREATE PROCEDURE `bdtest`.`paraSortie` (out nb int)
BEGIN
 
SELECT max(id) INTO nb FROM tableTest;
 
END

Et le code php :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
try {
   $dbh = new PDO('mysql:host=localhost;dbname=bdtest', 'utBase', 'hwQTMMvCEa35aeHF');
 
// pour entrée
$stmt = $dbh->prepare("CALL paraEntree(?)");
$stmt->bindParam(1, $nb, PDO::PARAM_STR,20);
$value = 'rrr';
$stmt->execute();
 
// pour sortie
$stmt = $dbh->prepare("CALL paraSortie(?)");
$stmt->bindParam(1, $return_value, PDO::PARAM_STR, 20);
// Appel de la procédure stockée
$stmt->execute();
print "La procédure a retourné : $return_value\n";
 
   $dbh = null;
} 
catch (PDOException $e) {
echo $e->errorInfo() ;
}
?>
Il y a donc problème dans le passage de paramètre car sans paramètre c'est ok et les tests des procédures direct sur mysql sont ok !

help
merci
sebpern est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/01/2008, 18h28   #2
Modérateur
 
Avatar de mathieu
 
Inscription : juin 2003
Messages : 4 893
Détails du profil
Informations forums :
Inscription : juin 2003
Messages : 4 893
Points : 4 466
Points : 4 466
Citation:
Envoyé par sebpern Voir le message
pbl ds passage parametre car sans para c ok et test des proc direct sur mysql ok !
je n'ai pas compris, quel est ton problème ?
__________________
Modérateur PHP
mathieu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/01/2008, 11h33   #3
Invité régulier
 
Inscription : mars 2007
Messages : 48
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 48
Points : 8
Points : 8
Par défaut explication

alors, je souhaite appeler une procedure stockée, crée sous MYSQL5, depuis le PHP.

avec une procedure stockée sans parametre : pas de soucis

mais lorsque j'ai une procedure stockée avec des paramètres ( entrée ou sortie ) cela ne marche pas : en effet j'appelle ma procedure stockée avec le parametre en sortie et ds mon PHP je ne recupère pas les valeurs que la procédure stockée est censé copier. Cependant je n'ai pas d'erreur.

voila mon soucis
et je ne comprend pas pourquoi
sebpern est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/01/2008, 22h18   #4
Modérateur
 
Avatar de mathieu
 
Inscription : juin 2003
Messages : 4 893
Détails du profil
Informations forums :
Inscription : juin 2003
Messages : 4 893
Points : 4 466
Points : 4 466
ll y a un bug avec l'API MySQL utilisé par PDO, tu dois passer par une variable MySQL pour récupérer la valeur, regarde là :
http://bugs.php.net/bug.php?id=35935
__________________
Modérateur PHP
mathieu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/01/2008, 16h43   #5
Invité régulier
 
Inscription : mars 2007
Messages : 48
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 48
Points : 8
Points : 8
Par défaut merci bcp et pour un parametre en entree

et pour envoyer une valeur à un paramètre en entrée je dois faire comment ?
encore merci
sebpern est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/01/2008, 17h04   #6
Invité régulier
 
Inscription : mars 2007
Messages : 48
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 48
Points : 8
Points : 8
Par défaut c ok

merci encore pour ton aide
sebpern est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 13h52.


 
 
 
 
Partenaires

Hébergement Web