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 :

Passer le nom d'une table en paramètre d'une procédure


Sujet :

SQL Procédural MySQL

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Février 2011
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Février 2011
    Messages : 8
    Points : 1
    Points
    1
    Par défaut Passer le nom d'une table en paramètre d'une procédure
    bonjour tout le monde ,
    Je souhaite creer un procedure Affichage en donnant le nom de la table en parametre en mysql .

    aide moi svp .
    voci mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    DELIMITER | -- On change le délimiteur
    CREATE PROCEDURE affiche(IN v_table VARCHAR(30))
     
    BEGIN
        SELECT *
        FROM v_table; 
    END|

  2. #2
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    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 : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    salut,

    tu peux pas le faire directement comme ça

    tu dois utiliser une requête préparée dans ta procédure

    ta requête est concaténée avec ta variable contenant le nom de la table puis mise dans une variable globale text que tu exécute dans une requête préparée...

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    DELIMITER | -- On change le délimiteur
    CREATE PROCEDURE affiche(IN v_table VARCHAR(30))
    set @t=concat('select * from ',v_table);
    prepare exe from @t;
    execute exe;
    deallocate prepare exe;
    end|
    delimiter ;

  3. #3
    Nouveau Candidat au Club
    Inscrit en
    Février 2011
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Février 2011
    Messages : 8
    Points : 1
    Points
    1
    Par défaut probleme de requette dynamique
    Merci beaucoup sa marche très bien.
    est si je veut créer une procédure insertion ,suppression ou modification ?

  4. #4
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    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 : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    ça suit la même logique...

  5. #5
    Nouveau Candidat au Club
    Inscrit en
    Février 2011
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Février 2011
    Messages : 8
    Points : 1
    Points
    1
    Par défaut probleme de requette dynamique
    Mais je crée une procédure de suppression il me génère des erreurs .
    voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    DELIMITER |
    CREATE PROCEDURE `supprimer`(IN v_table VARCHAR(30), IN id_table VARCHAR(20) )
    BEGIN
    SET @re=concat('DELETE from ',v_table,' where NUM =',id_table,''  );
    prepare req from @re;
    execute req;
    deallocate prepare req;
    end |

  6. #6
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    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 : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    au passage le ",''" à la fin du concat ne sert à rien..

    sinon y a pas d'erreur de syntaxe à priori ce qui veut dire que c'est une erreur de contexte (table inexistence, emploi de ta fonction qui contient une requête préparée coté serveur dans une requête préparée coté serveur, mauvais nom de colonne dans la table visée, etc.)...

    quand tu parles d'erreur il faut les donner !

Discussions similaires

  1. Réponses: 1
    Dernier message: 21/06/2015, 18h59
  2. Comment passer le nom de la table en paramètre
    Par eperier dans le forum SQL*Loader
    Réponses: 1
    Dernier message: 30/05/2013, 13h47
  3. Réponses: 6
    Dernier message: 24/05/2013, 16h25
  4. Faire du nom de la table un paramètre dans une requête
    Par sofiane1111 dans le forum Bases de données
    Réponses: 2
    Dernier message: 20/09/2007, 14h27
  5. Faire passer une table en paramètre pour une procedure
    Par samplaid dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 10/02/2006, 11h26

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