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

PL/SQL Oracle Discussion :

Comment pour DROP DIRECTORY


Sujet :

PL/SQL Oracle

  1. #1
    Membre à l'essai
    Inscrit en
    Mars 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 5
    Par défaut Comment pour DROP DIRECTORY
    Bonjour à tous,

    Je développe sous SQL Developper et je n'arrive pas à supprimer une directory.

    Voilà la structure de mon code :
    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
    Create or replace Directory "file_table" as '/data/par/';
    Create or replace Directory "file_ctl" as '/appli/ctl/';
    GRANT WRITE ON DIRECTORY "file_ctl" TO PUBLIC; 
     
    declare
    ....
    BEGIN
       --- Lecture fichier entrée
       loop
       ...
           --- Ecriture fichier sortie
       end loop;
       EXCEPTION
       ....
       -- Fermeture des fichiers
       ....
    END;
     
    Drop Directory "file_table";
    Drop Directory "file_ctl";
    Message d'erreur :
    PLS-00103: Symbole "DROP" rencontré
    06550. 00000 - "line %s, column %s:\n%s"
    *Cause: Usually a PL/SQL compilation error.
    *Action:
    Si quelqu'un peut m'expliquer pourquoi et comment faire.
    Merci d'avance.
    Novamane.

  2. #2
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    il faut utiliser EXECUTE IMMEDIATE pour exécuter du code SQL dans un code PL/SQL

  3. #3
    Membre à l'essai
    Inscrit en
    Mars 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 5
    Par défaut
    J'ai pensé à mettre un "execute immediate" en fin de code,
    mais voilà le drop n'est pas fait puisque quand je vais voir
    All_directories, elles s'y sont toujours.

    --- Suppression de la directory ---
    execute immediate 'Drop Directory "file_table"';
    execute immediate 'Drop Directory "file_ctl"';

    --- Controle des directories
    select * from all_directories

    Je pense que le "execute immediate" n'exexute pas la commande
    car le "drop directory" en direct ne marche pas non plus.

    J'ai remarqué quand je mets la commande Drop Directory "file_table"
    avant le "décalre" de mon code, la commande est exécuté correctement.
    pourquoi, je ne sais pas ?

    Moi je veux que cette commande s'exécute en fin de code pas au début.

    Merci de me répondre.

  4. #4
    Membre chevronné Avatar de xdescamp
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 300
    Par défaut
    Il manque un "/" pour terminer et exécuter le bloc PL/SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    CREATE ...
    ...
    DECLARE
    ...
    BEGIN
    ...
    END;
    /
    ...
    DROP ...

  5. #5
    Membre à l'essai
    Inscrit en
    Mars 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 5
    Par défaut
    Merci à vous deux, c'est bien le "/" qui manquait aprés le dernier END.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. If == / mais comment pour If (pas égal à)
    Par delavega dans le forum Flash
    Réponses: 2
    Dernier message: 04/04/2007, 10h39
  2. comment proteger parent directory
    Par Rajhonson dans le forum Langage
    Réponses: 5
    Dernier message: 20/11/2006, 14h49
  3. comment changer le DIRECTORIE du HELP
    Par d-a-v-e dans le forum MFC
    Réponses: 10
    Dernier message: 01/03/2006, 15h29
  4. Réponses: 14
    Dernier message: 14/02/2005, 02h36
  5. [MFC?] Comment récupérer la directory de l'exécutable?
    Par bigboomshakala dans le forum MFC
    Réponses: 9
    Dernier message: 14/05/2004, 15h22

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