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 :

Ecrire sur la sortie standard à partir d'une procédure stockée


Sujet :

PL/SQL Oracle

  1. #1
    Nouveau membre du Club
    Inscrit en
    Avril 2006
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 56
    Points : 37
    Points
    37
    Par défaut Ecrire sur la sortie standard à partir d'une procédure stockée
    Bonjour,

    j'ai un script SQL (stocké dans un fichier .SQL) qui exécute une procédure stockée. Ce fichier SQL est exécuté par un fichier de commande .BAT qui génère un fichier de LOG en utilisant la commande SPOOL. Je souhaiterais que ma procédure stockée puisque générer des logs qui sont interceptées par le SPOOL pour les écrire dans le fichier de LOG. Je pensais qu'en utilisant la commande DMS_OUTPUT.Putline() cela fonctionnerait mais ce n'est pas le cas.

    Pourriez-vous me donner des pistes?

    merci,

    Romu

  2. #2
    Expert éminent
    Avatar de pachot
    Homme Profil pro
    Developer Advocate YugabyteDB
    Inscrit en
    Novembre 2007
    Messages
    1 821
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Developer Advocate YugabyteDB
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 821
    Points : 6 443
    Points
    6 443
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    dbms_output.put_line devrait fonctionner si 'set serveroutput on' est positionné sous sqlplus.

    Cordialement,
    Franck.
    Franck Pachot - Developer Advocate Yugabyte 🚀 Base de Données distribuée, open source, compatible PostgreSQL
    🗣 twitter: @FranckPachot - 📝 blog: blog.pachot.net - 🎧 podcast en français : https://anchor.fm/franckpachot

  3. #3
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par pachot Voir le message
    dbms_output.put_line devrait fonctionner si 'set serveroutput on' est positionné sous sqlplus.
    ou dbms_output.enable en pl/sql.

  4. #4
    Nouveau membre du Club
    Inscrit en
    Avril 2006
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 56
    Points : 37
    Points
    37
    Par défaut
    OK je vais essayer. Merci.

  5. #5
    Nouveau membre du Club
    Inscrit en
    Avril 2006
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 56
    Points : 37
    Points
    37
    Par défaut
    Bonjour,

    malheureusement ça ne fonctionne pas dans le .BAT
    Lorsque j'exécute la procédure stockée dans TOAD, mes résultats sont bien écrits dans le DBMS_OUTPUT. Par contre, lorsque j'exécute ma procédure stockée via un script SQL appelé par un BAT, les résultats ne sont pas renvoyés sur la sortie standard du SQL (que j'ai redirigé dans un fichier de LOG avec la fonction SPOOL).

    une idée?

  6. #6
    Expert éminent
    Avatar de pachot
    Homme Profil pro
    Developer Advocate YugabyteDB
    Inscrit en
    Novembre 2007
    Messages
    1 821
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Developer Advocate YugabyteDB
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 821
    Points : 6 443
    Points
    6 443
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    pour utiliser dbms_output, il faut:
    1- l'activer (dbms_output.enable)
    2- le lire (dbms_output.get_lines)

    si tu utilises 'set serveroutput on' sqlplus fait les 2:
    1- il l'active
    2- il lit et affiche à la fin de chaque commande

    si tu utilise TOAD, il fait les 2 aussi quand tu l'active

    si tu utilise toi-même 'dbms_output.enable' alors il faut aussi le lire.

    Cordialement,
    Franck.
    Franck Pachot - Developer Advocate Yugabyte 🚀 Base de Données distribuée, open source, compatible PostgreSQL
    🗣 twitter: @FranckPachot - 📝 blog: blog.pachot.net - 🎧 podcast en français : https://anchor.fm/franckpachot

Discussions similaires

  1. [Lazarus] Ecrire sur la sortie standard stdout
    Par SergioMaster dans le forum Lazarus
    Réponses: 4
    Dernier message: 27/09/2009, 14h00
  2. Ecrire sur la sortie standard avec write
    Par overlolo dans le forum Débuter
    Réponses: 8
    Dernier message: 13/04/2009, 00h07
  3. Ecrire sur la sortie standard
    Par red210 dans le forum Débuter
    Réponses: 1
    Dernier message: 14/04/2008, 11h27
  4. Réponses: 9
    Dernier message: 15/10/2007, 10h20
  5. Réponses: 8
    Dernier message: 07/09/2006, 11h43

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