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 :

Controler l'existence d'une fonction


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 183
    Par défaut Controler l'existence d'une fonction
    Bonjour a tous,

    Je viens de créer ma première fonction mysql (qui fonctionne).
    Maintenant je souhaite créer cette fonction uniquement si elle n'existe pas.

    Dans la doc mysql j'ai trouvé un commande qui permet de supprimer une fonction si elle existe :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    DROP FUNCTION IF EXISTS `nom_de_la_fonction`;
    Existe-t-il une commande qui me permettrait de faire une sorte de :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    IF NOT EXISTS `nom_de_la_fonction` CREATE DEFINER = CURRENT_USER FUNCTION `nom_de_la_fonction`(......... etc
    Dans l'attente je peux supprimer systématiquement la fonction puis la recréer mais je ne trouve pas cela très élégant.

    Comment faite-vous ?

    Merci a vous.

  2. #2
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 183
    Par défaut
    Apparemment il n'y pas de commande mysql native pour controler cela.

    J'ai donc utilisé ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT COUNT(*)
    FROM `mysql`.`proc` 
    WHERE `name` = 'ma_fonction'

  3. #3
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 059
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 059
    Par défaut
    Bonjour,

    Effectivement, il n'y a pas de syntaxe pour ça (pas d'équivalent au CREATE OR REPLACE FUNCTION de PostgreSQL, par exemple).
    Tu peux aussi voir si une fonction existe en interrogeant le catalogue MySQL.

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/05/2006, 13h45
  2. Passer un contrôle en paramètre d'une fonction
    Par Kinian dans le forum Access
    Réponses: 6
    Dernier message: 15/05/2006, 11h15
  3. Réponses: 4
    Dernier message: 28/10/2005, 16h30
  4. Réponses: 5
    Dernier message: 13/10/2005, 12h46
  5. [LG] Contrôle d'existence d'une variable ?
    Par Aenigma dans le forum Langage
    Réponses: 4
    Dernier message: 21/09/2005, 06h59

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