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 :

execute immediate avec utl_file [12c]


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2017
    Messages : 12
    Par défaut execute immediate avec utl_file
    Bonjour,
    Dans ma procédure stockée, j'initialise :
    - un fichier trace myfic := UTL_FILE.FOPEN
    - une variable stmt pour un sql dynamique.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    stmt := '
    BEGIN
      for cursor as ... LOOP 
        traitement de type insert/update 
        /* ici je voudrais faire un appel à UTL_FILE.PUT(myfic, 'mon message'); */
      END LOOP
    END;
    '
    Ensuite, j'écris dans le fichier de trace je lance 'execute immediate stmt' cf. stmt ci-dessus
    Par contre je n'arrive pas à enrichir ce traitement dynamique par un appel à UTL_FILE pour chaque itération du curseur.
    Comment passer le pointeur myfic (UTL_FILE.FILE_TYPE) à sql dynamique ?
    Ce handler UTL_FILE.FILE_TYPE étant une structure :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    TYPE file_type IS RECORD (
       id          BINARY_INTEGER, 
       datatype    BINARY_INTEGER,
       byte_mode   BOOLEAN);
    je n'arrive pas à l'inclure l'appel à UTL_FILE.PUT dans 'execute immediate'.
    Auriez-vous des solutions ?

    Cdlt

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Il est fort probable que vous concevez mal votre traitement. Néanmoins, essayez de poster un jeu de test simplifié de ce que vous voulez accomplir.

  3. #3
    Membre averti
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2017
    Messages : 12
    Par défaut Question simplifiée
    Bonjour,
    pour simplifier voici ma question :
    est-il possible d'exécuter avec 'execute immediate' une procédure PLSQL ayant en paramètre 'IN' un pointeur sur le fichier de type UTL_FILE.FILE_TYPE
    ouvert au préalable dans la procédure appelante ?

    Ceci dans le but de générer un fichier log global du traitement.

    Cdlt

  4. #4
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Non le type de binding ne passe pas il est inconnu pour le moteur SQL.
    Par contre tout le monde pourrait écrire dans une table temporaire à vider dans un fichier en fin de traitement.

  5. #5
    Membre averti
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2017
    Messages : 12
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Non le type de binding ne passe pas il est inconnu pour le moteur SQL.
    Par contre tout le monde pourrait écrire dans une table temporaire à vider dans un fichier en fin de traitement.
    Bonjour mnitu,
    je vais effectivement me rabattre sur cette solution de table journal, bien qu'elle ne permette pas de suivre l'avancement en temps réel et reste dépendante du commit final donc en cas d'un plantage ...
    Merci en tout cas de ton avis éclairé.
    Cdlt

  6. #6
    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
    Pour des logs vous pouvez utiliser une transaction autonome

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

Discussions similaires

  1. EXECUTE IMMEDIATE avec CREATE puis INSERT
    Par Hobbi1 dans le forum PL/SQL
    Réponses: 2
    Dernier message: 23/10/2015, 13h02
  2. Pb avec Execute IMMEDIATE et bloc dynamique
    Par ouaouane dans le forum SQL
    Réponses: 5
    Dernier message: 28/02/2008, 16h08
  3. EXECUTE IMMEDIATE avec fonction
    Par aechevar dans le forum Oracle
    Réponses: 1
    Dernier message: 07/07/2006, 20h05
  4. [oracle 8.1.7] pbm de privilège avec execute immediate
    Par Nounoursonne dans le forum Oracle
    Réponses: 4
    Dernier message: 10/02/2006, 16h45
  5. Réponses: 2
    Dernier message: 05/01/2006, 10h43

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