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

Trigger qui vérifie l'existence de fichiers [Fait]


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut Trigger qui vérifie l'existence de fichiers
    Bonjour,

    Je souhaiterai créer un trigger qui vérifie l'existence d'un fichier lors de la saisie de son nom dans une table oracle.
    Par exemple: l'utilisateur peut saisir le nom d'une photo qu'il a prise et le trigger doit vérifier si cette photo existe bien dans une arborescence donnée.

    Est-ce faisable?

    Merci pour votre aide!

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Salut,

    Regarde du côté de UTL_FILE

  3. #3
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut
    J'ai lu le tutorial sur UTL_FILE mais je m'en sors pas trop.

    Quelqu'un pourrait me donner un exemple concret pour vérifier l'existence d'un fichier.

    D'avance merci

  4. #4
    Scorpi0
    Invité(e)
    Par défaut
    A quel niveau tu bloques ?

  5. #5
    Membre émérite Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Par défaut
    tu peux te servir de fopen et gérer l'exception INVALID_PATH ce qui voudrait dire que ton fichier n'existe pas.

  6. #6
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut
    Bein, je sais pas vraiment comment utiliser la fonction FGETATTR.

    Le tutorial me donne celà mais pas d'exemple concret, je suppose qu'il faut déclarer UTL_FILE, et saisir la commande differement.

    Lecture des attributs d'un fichier

    UTL_FILE.FGETATTR(
    repertoire IN VARCHAR2,
    fichier IN VARCHAR2,
    exists OUT BOOLEAN,
    taille_fichier OUT NUMBER,
    taille_bloc OUT NUMBER)

    repertoire représente le répertoire Oracle
    fichier représente le nom du fichier avec son extension
    exists vaut TRUE si le fichier existe, sinon FALSE
    taille_fichier représente la taille du fichier en octets
    taille_bloc représente la taille d'un bloc système en octets

    Cette fonction teste l'existence d'un fichier et récupère, dans l'affirmative, la taille du fichier et la taille du bloc système

  7. #7
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Directement tiré de la procédure Ouvrir_fichier :

    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
    SQL> declare
      2  PC$Nom_Fichier varchar2(50) := 'toto.jpg';
      3  PC$Dir varchar2(50) := '/path/de/ton/directory/';
      4  v_file utl_file.file_type;
      5  LC$Msg     Varchar2(256);
      6  begin
      7  v_file := utl_file.fopen( PC$Dir, PC$Nom_Fichier, 'r');
      8  dbms_output.put_line('le fichier existe');
      9  exception
     10     When UTL_FILE.INVALID_PATH Then
     11     LC$Msg := 'le fichier '||PC$Nom_Fichier||' n''existe pas';
     12     dbms_output.put_line( LC$Msg ) ;
     13  end;
     14  /
    le fichier toto.jpg n'existe pas
     
    Procédure PL/SQL terminée avec succès.
    Par contre pour un trigger utilise RAISE_APPLICATION_ERROR, et les autres exceptions.

  8. #8
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut
    Si je saisie le script de skuatamad il me fait une erreur:

    PLS-00201: L'identificateur 'UTL_FILE' doit etre declare

    Comment puis déclarer UTL_FILE?

  9. #9
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    C'est que tu n'as pas les droits sur utl_file.

  10. #10
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut
    J'ai accès à l'utilisateur SYSTEM donc je peux me les donner.
    Comment faire pour avoir les droits?

  11. #11
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    Citation Envoyé par roman67 Voir le message
    J'ai accès à l'utilisateur SYSTEM donc je peux me les donner.
    Comment faire pour avoir les droits?
    Normalement, c'est avec l'utilisateur SYS.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    grant execute on utl_file to myuser;

Discussions similaires

  1. Script qui vérifie si le fichier a été modifié
    Par 20132014 dans le forum Shell et commandes GNU
    Réponses: 14
    Dernier message: 29/10/2014, 00h55
  2. Trigger qui vérifie inscription à un groupe
    Par Darkjovem dans le forum Développement
    Réponses: 14
    Dernier message: 28/04/2011, 14h56
  3. Trigger qui vérifie l'insertion en base
    Par wapette21 dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 21/10/2010, 10h08
  4. Réponses: 1
    Dernier message: 28/07/2009, 18h13
  5. faire un logiciel qui fait parsing d'un fichier xml existant sur le serveur
    Par wajdiisi2007 dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 08/08/2007, 12h09

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