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 Firebird Discussion :

script vérifiant l'existence d'une procédure avant sa suppression


Sujet :

SQL Firebird

  1. #1
    Membre régulier
    Inscrit en
    Mars 2002
    Messages
    240
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 240
    Points : 102
    Points
    102
    Par défaut script vérifiant l'existence d'une procédure avant sa suppression
    bonjour,

    j'essaie de créer un script sql (pour firebird/interbase) qui vérifie si une procedure stockée existe dans la base. si c'est le cas, je la supprime. ensuite je la recrée. mon script ci-dessous ne marche pas car il ne reconnait pas l'instruction IF. comment faire svp car je ne sais pas à l'avance si les bases concernées par le script de mise à jour ont ou pas cette procedure stockée ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    IF EXISTS(SELECT RDB$PROCEDURE_NAME FROM RDB$PROCEDURES WHERE RDB$PROCEDURE_NAME = 'SPR_INVPRODBRUTZONE')
    DROP PROCEDURE SPR_INVPRODBRUTZONE;
     
    SET TERM ^ ;
     
    CREATE PROCEDURE SPR_INVPRODBRUTZONE
    AS
    DECLARE VARIABLE CODE NUMERIC(9, 3);
    BEGIN
    ...
    ...
    etc

  2. #2
    Expert confirmé
    Avatar de Ph. B.
    Homme Profil pro
    Freelance
    Inscrit en
    Avril 2002
    Messages
    1 784
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 784
    Points : 5 915
    Points
    5 915
    Par défaut
    Bonjour,

    Dans votre cas, pourquoi ne pas utiliser CREATE OR ALTER ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    CREATE OR ALTER PROCEDURE SPR_INVPRODBRUTZONE
    AS
    DECLARE VARIABLE CODE NUMERIC(9, 3);
    BEGIN
    ...
    ...
    etc
    ou RECREATE PROCEDURE ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    RECREATE PROCEDURE SPR_INVPRODBRUTZONE
    AS
    DECLARE VARIABLE CODE NUMERIC(9, 3);
    BEGIN
    ...
    ...
    etc
    Enfin, si vous tenez à faire compliqué, vous pouvez écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    EXECUTE BLOCK AS BEGIN
    IF (EXISTS(SELECT 1 FROM RDB$PROCEDURES WHERE RDB$PROCEDURE_NAME = 'SPR_INVPRODBRUTZONE'))
    THEN
      EXECUTE STATEMENT 'DROP PROCEDURE SPR_INVPRODBRUTZONE;';
     
    EXECUTE STATEMENT 'CREATE PROCEDURE SPR_INVPRODBRUTZONE
    AS
    DECLARE VARIABLE CODE NUMERIC(9, 3);
    BEGIN
    ...
    ...
    etc
    Philippe.

Discussions similaires

  1. Réponses: 12
    Dernier message: 11/10/2023, 17h14
  2. [MySQL] Vérifier l'existance d'une entrée avant l'insertion dans une BD
    Par mitchb dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 22/02/2008, 13h30
  3. Réponses: 5
    Dernier message: 13/06/2007, 16h23
  4. Réponses: 2
    Dernier message: 19/05/2007, 16h38
  5. Réponses: 1
    Dernier message: 14/11/2005, 16h51

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