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 22/01/2007, 07h22   #1
Nouveau Membre du Club
 
Inscription : août 2003
Messages : 52
Détails du profil
Informations forums :
Inscription : août 2003
Messages : 52
Points : 37
Points : 37
Par défaut PB Procédure stockée avec phpMyAdmin

Bonjour à tous,

J'essaye de créer une procédure stockée avec phpMyAdmin sur une base MySQL v5.0.27

Voici le code de ma procédure et la réponse de MySQL :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
CREATE PROCEDURE ReplaceTime()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;
DECLARE cur CURSOR FOR SELECT findex,date, time FROM matable;
DECLARE ffindex, fdate, ftime, ftemp VARCHAR(128);
 
OPEN cur;
 
REPEAT
FETCH cur INTO ffindex,date, ftime;
IF NOT done THEN
 ftime = RIGHT(ftime,8);
 fdate = LEFT(fdate,10);
 ftemp = CONCAT(fdate,ftime);
 
UPDATE matable SET Date = ftemp WHERE findex = ffindex;
END IF;
UNTIL done END REPEAT;
 
CLOSE cur;
END
Code :
1
2
 
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INT DEFAULT 0' at line 3
J'ai lu sur le forum que la syntaxe pour les procédure étaient liée au client, et que phpMyAdmin ne supporterai pas les ;

Est ce que ça veut dire que c'est alors impossible avec phpMyadmin ? J'ai fait essayer ce code a une personne qui utilise mySQLquerry et il semble également avoir des erreurs de syntaxe. (Mais pas les mêmes, je vais essayer de récupérer son message d'erreur).

Si quelqu'un à une idée sur le sujet.... merci

A+
__________________
C'est au pied du mur que l'on voit le mieux le mur!!!!!
ythierrin est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 22/01/2007, 08h09   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
plutôt que phpMyAdmin, passe par mysql_query.

pour les erreurs résiduelles, j'en vois trois :
Code :
1
2
3
4
SET ftime = RIGHT(ftime,8);
SETSET fdate = LEFT(fdate,10);
SET ftemp = CONCAT(fdate,ftime);
attention aussi à tes colonnes `date` et `time`!

Enfin, ta procédure avec curseur serait avantageusement remplacée par une simple requête :

Code :
1
2
UPDATE matable 
SET `Date` = CONCAT(LEFT(`date`, 10), RIGHT(`time` ,8)) ;
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 22/01/2007, 13h00   #3
Nouveau Membre du Club
 
Inscription : août 2003
Messages : 52
Détails du profil
Informations forums :
Inscription : août 2003
Messages : 52
Points : 37
Points : 37
Ok, merci pour les tyaux.

J'utilise désormais MySql Querry et avec la simple requête que tu m'envoie c'est bon ça marche.

Bonne journée et encore merci.
__________________
C'est au pied du mur que l'on voit le mieux le mur!!!!!
ythierrin est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/04/2008, 16h52   #4
Invité de passage
 
Inscription : avril 2008
Messages : 1
Détails du profil
Informations forums :
Inscription : avril 2008
Messages : 1
Points : 1
Points : 1
Pour ceux qui souhaiteraient toutefois passer par phpMyAdmin, sachez qu'il s'agit d'utiliser un "DELIMITER", ce qui donnerait donc le code suivant pour la procédure précédente:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
CREATE PROCEDURE ReplaceTime()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;
DECLARE cur CURSOR FOR SELECT findex,date, time FROM matable;
DECLARE ffindex, fdate, ftime, ftemp VARCHAR(128);
 
OPEN cur;
 
REPEAT
FETCH cur INTO ffindex,date, ftime;
IF NOT done THEN
 ftime = RIGHT(ftime,8);
 fdate = LEFT(fdate,10);
 ftemp = CONCAT(fdate,ftime);
 
UPDATE matable SET Date = ftemp WHERE findex = ffindex;
END IF;
UNTIL done END REPEAT;
 
CLOSE cur;
END$$
avec un DELIMITER défini à $$ dans la popup SQL de phpMyAdmin
mlagree 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 17h58.


 
 
 
 
Partenaires

Hébergement Web