Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
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 14/06/2011, 12h40   #1
Invité de passage
 
Inscription : octobre 2008
Messages : 16
Détails du profil
Informations forums :
Inscription : octobre 2008
Messages : 16
Points : 3
Points : 3
Par défaut PHP : Procédure stockée

Bonjour,

J'ai un problème avec une procédure stockée sauvegardé sur phpMyAdmin que j'appelle avec PHP.

Le but de cette procédure stockée est de vérifier que le titre n'a pas déjà été utilisé lors d'un nouvel enregistrement.

Pour ce faire j'utilise la procédure stockée suivante :

Code :
1
2
3
4
CREATE procedure verify_unique_title_procedure(titre_in text, num_in int, out titre_out text)
BEGIN
SELECT titre_livret INTO titre_out FROM guide WHERE titre_livret = titre_in AND id <> num_in;
END
Nous devons donc spécifier en valeurs d'entrées le titre que nous souhaitons et l'identifiant (qui sera égal à rien si nous insérons une ligne ou 0, j'ai essayé les deux). En valeur de sortie, nous avons le titre si ils étaient identiques, ou rien si ils sont différents.

J'ai testé sous phpMyAdmin, la procédure stockée marche très bien.

En utilisant ce code PHP :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public FUNCTION callStoredProcedure($paramNum_in, $paramTitle_in)
	{
		echo $paramNum_in; //Affiche le numéro
		echo $paramTitle_in; // Affiche un texte
 
		$paramTitle_out = '';
		$query = $this->bdd->prepare("CALL verify_unique_title_procedure(titre_in, num_in, titre_out)");
		$query->bindParam('titre_in', $paramTitle_in, PDO::PARAM_STR, 50);
		$query->bindParam('num_in', $paramNum_in, PDO::PARAM_INT);
		$query->bindParam('titre_out', $paramTitle_out, PDO::PARAM_STR, 50);
		$query->execute();
 
		echo $paramTitle_out; // Egal à rien si les titres étaient différents mais le même que celui du paramètre d'entrée si les titres étaient identiques.
 
		return $paramTitle_out;
	}
Les deux "echo" du début affiche bien les valeurs. Mais que je mette un titre déjà utilisé ou non, $paramTitle_out est égal à rien.

Merci d'avance,
Sylra.
Sylra est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 17h16   #2
Membre Expert
 
Homme Eric Dureuil
Développeur informatique
Inscription : avril 2011
Messages : 853
Détails du profil
Informations personnelles :
Nom : Homme Eric Dureuil
Localisation : France, Isère (Rhône Alpes)

Informations professionnelles :
Activité : Développeur informatique
Secteur : High Tech - Multimédia et Internet

Informations forums :
Inscription : avril 2011
Messages : 853
Points : 1 332
Points : 1 332
salut,

exécute ta requête comme ça déjà pour la tester avec des valeurs qui marchent car j'ai l'impression qu'elle renvoie rien... vu qu'il n'y a qu'elle dans ta procédure...

une des conditions doit poser un problème...
__________________
Eric Dureuil, développeur web, c/c++, java indépendant
soyons
pensez à mettre et
ericd69 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 18h01   #3
Invité de passage
 
Inscription : octobre 2008
Messages : 16
Détails du profil
Informations forums :
Inscription : octobre 2008
Messages : 16
Points : 3
Points : 3
Citation:
Envoyé par ericd69 Voir le message
salut,

exécute ta requête comme ça déjà pour la tester avec des valeurs qui marchent car j'ai l'impression qu'elle renvoie rien... vu qu'il n'y a qu'elle dans ta procédure...

une des conditions doit poser un problème...
J'ai déjà essayé avec des valeurs définies... malheureusement ceci ne change rien.

Est-ce que les lignes que j'ai utilisé dans mon code PHP sont correctes ?


Il n'y aurait pas quelque chose à activer avec WAMP pour permettre l’exécution des procédures stockées ?
Sylra est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/06/2011, 10h40   #4
Membre Expert
 
Avatar de kain_tn
 
Homme
Inscription : mars 2005
Messages : 577
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Canada

Informations forums :
Inscription : mars 2005
Messages : 577
Points : 1 209
Points : 1 209
Bonjour,

il me semble que ton problème se situe au niveau du binding avec PDO:

Code :
1
2
3
4
5
$query = $this->bdd->prepare("CALL verify_unique_title_procedure(titre_in, num_in, titre_out)");
$query->bindParam('titre_in', $paramTitle_in, PDO::PARAM_STR, 50);
$query->bindParam('num_in', $paramNum_in, PDO::PARAM_INT);
$query->bindParam('titre_out', $paramTitle_out, PDO::PARAM_STR, 50);
Il me semble que c'est plutôt comme ça qu'il faut écrire les paramètres nommés:

Code :
1
2
3
4
5
$query = $this->bdd->prepare("CALL verify_unique_title_procedure(:titre_in, :num_in, :titre_out)");
$query->bindParam(':titre_in', $paramTitle_in, PDO::PARAM_STR, 50);
$query->bindParam(':num_in', $paramNum_in, PDO::PARAM_INT);
$query->bindParam(':titre_out', $paramTitle_out, PDO::PARAM_STR, 50);
__________________
Copier c'est copier; voler c'est vendre un CD une vingtaine d'euros!


Code C :
1
2
3
4
5
6
7
#include <stdio.h>
 
int main(int argc, char **argv) {
 
    printf("So long, and thanks for the fish, Dennis...\n");
    return 0;
}
kain_tn est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/06/2011, 14h05   #5
Membre Expert
 
Homme Eric Dureuil
Développeur informatique
Inscription : avril 2011
Messages : 853
Détails du profil
Informations personnelles :
Nom : Homme Eric Dureuil
Localisation : France, Isère (Rhône Alpes)

Informations professionnelles :
Activité : Développeur informatique
Secteur : High Tech - Multimédia et Internet

Informations forums :
Inscription : avril 2011
Messages : 853
Points : 1 332
Points : 1 332
tu dois activé les requêtes multiples car c'est pas activé de base:
Code php :
$this->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, true);

selon les versions de pdo cette valeur par défaut a changé... les procédures stockées permettant les requêtes multiple en 1 appel, tu dois activer la bufferisation des résultats (même si tu t'en sers pas vraiment)
__________________
Eric Dureuil, développeur web, c/c++, java indépendant
soyons
pensez à mettre et
ericd69 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h11.


 
 
 
 
Partenaires

Hébergement Web