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 :

Problème de procédure stockée Erreur MySQL 1064


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Développeur Web
    Inscrit en
    Novembre 2008
    Messages
    146
    Détails du profil
    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Novembre 2008
    Messages : 146
    Par défaut Problème de procédure stockée Erreur MySQL 1064
    Bonjour tout le monde
    j'héberge mon site web chez ovh.
    j'essaye d’exécuter la procédure stockée suivante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
    CREATE DEFINER=`mon_nom`@`localhost` PROCEDURE `sp_count`(IN `tableName` VARCHAR(255), IN `clause` VARCHAR(255))
    BEGIN
    SET @stmt_sql=CONCAT("select COUNT(*) as count  from ", tableName," ",clause);
     
      PREPARE stmt_count FROM @stmt_sql;
     
      EXECUTE stmt_count;
     
      DEALLOCATE PREPARE stmt_count;
     
        END$$
     
    CREATE DEFINER=`mon_nom`@`localhost` PROCEDURE `sp_delete`(IN `tableName` VARCHAR(100), IN `claus` VARCHAR(100))
        SQL SECURITY INVOKER
    BEGIN
     
         IF claus<>'' THEN
     
          SET @stmt_sql=CONCAT("DELETE FROM ", tableName," WHERE ",claus);
     
         ELSE 
     
          SET @stmt_sql=CONCAT("DELETE FROM ", tableName);
     
         END IF;
     
         PREPARE stmt FROM @stmt_sql;
     
         EXECUTE stmt;
     
         DEALLOCATE PREPARE stmt;
     
        END$$
    Mysql me délivre ce message d'erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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 '' at line 4
    plus exactement cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SET @stmt_sql=CONCAT("select COUNT(*) as count  from ", tableName," ",clause);
    Je pense que le problème provoqué par les guillemet en rouge mais je ne sait pas comment corriger!
    Pourriez-vous m'aider svp ?
    Note: cette procédure tourne sans problème chez autre hébergeurs comme justhost et vipdomaine!
    Cordialement

  2. #2
    Membre confirmé
    Développeur Web
    Inscrit en
    Novembre 2008
    Messages
    146
    Détails du profil
    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Novembre 2008
    Messages : 146
    Par défaut
    Voila j'ai trouvé la solution

    il faut remplacer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DEFINER=`mon_nom`@`localhost`
    par

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE DEFINER=`mon_nom`@`%` PROCEDURE
    Donc voilà ... cela va peut être en sauver quelque uns qui galèrent.

Discussions similaires

  1. [MySQL] Problèmes avec les procédures stockées sous mysql
    Par GoTrUnKo dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 27/11/2008, 22h00
  2. Réponses: 7
    Dernier message: 03/05/2007, 12h44
  3. Réponses: 1
    Dernier message: 17/07/2006, 17h08
  4. [Procédure stockée] Erreur 1305
    Par SSJ17Vegeta dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 18/11/2005, 02h38
  5. Problème de procédure stockée
    Par Sorcier157 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 17/03/2005, 17h57

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