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

Oracle Discussion :

Exécution automatique et périodique d'une requête [9iR2]


Sujet :

Oracle

  1. #1
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tchad

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2011
    Messages : 22
    Points : 18
    Points
    18
    Par défaut Exécution automatique et périodique d'une requête
    Bonjour. Je souhaite exécuter automatiquement la requête(select) ci-dessous et exporter aussi automatiquement les données issues de cette dernière dans un fichier text suivant un intervalle de 15 minute.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     select ncp1,';', mon1, ';', sen1,';', lib1, ';',  to_date(sysdate,'DD/MM/YYYY'), ';',eve, ';'
    from bkeve
    where (ncp1 like '35%' or ncp1 like '36%' or ncp1 like '37%');
    Merci d'avance!

  2. #2
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    A mon sens, le plus simple est de le faire avec SQL*Plus et la fonction SPOOL.
    Et de planifier l'exécution au niveau du système d'exploitation.

    Sinon, vu que vous êtes en 9i, vous allez être obligé de créer une procédure basée sur UTL_FILE pour générer le fichier, et de déclencher cette procédure en mode récurrent avec DBMS_JOB.
    Cette solution me paraît nettement plus lourde.
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  3. #3
    Membre chevronné Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Points : 2 071
    Points
    2 071
    Par défaut
    Il y a juste une petite erreur dans la requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select ncp1,';', mon1, ';', sen1,';', lib1, ';', TO_CHAR(sysdate,'DD/MM/YYYY'), ';',eve, ';'
    from bkeve
    where (ncp1 like '35%' or ncp1 like '36%' or ncp1 like '37%');
    Garuda गरूड
    Brahmâ la Guerre et Vishnu la Paix

    Oracle 12C R2 - Forms11GR2 - Toad 12 - sharePoint 2010

  4. #4
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tchad

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2011
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Citation Envoyé par Pomalaix Voir le message
    A mon sens, le plus simple est de le faire avec SQL*Plus et la fonction SPOOL.
    Et de planifier l'exécution au niveau du système d'exploitation.
    Merci. J'arrive à extraire correctement les données à l'aide de la fonction SPOOL. Cependant, les données sont exportées avec les lignes de la commande de la requête. Je souhaite ne pas afficher les commandes de select ni les intitulés.

  5. #5
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Alors il faut ajouter en tête de votre script :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SET ECHO OFF
    SET PAGESIZE 0
    La première option désactive l'inclusion des commandes dans le SPOOL ; la seconde désactive les en-têtes de colonne et assure qu'il n'y aura pas de lignes vides à la place.
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  6. #6
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tchad

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2011
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Merci. J'ai ajouté les deux codes à l'entête. Cela a éliminé les intitulés. Mais les commandes de select sont encore la dans mon fichier généré. Merci d'avance pour l'aide.

  7. #7
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tchad

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2011
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Citation Envoyé par Garuda Voir le message
    Il y a juste une petite erreur dans la requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select ncp1,';', mon1, ';', sen1,';', lib1, ';', TO_CHAR(sysdate,'DD/MM/YYYY'), ';',eve, ';'
    from bkeve
    where (ncp1 like '35%' or ncp1 like '36%' or ncp1 like '37%');
    Merci. Je vais modifié ma requête pour la rendre plus conforme.

  8. #8
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Citation Envoyé par taradoum Voir le message
    ... Mais les commandes de select sont encore la dans mon fichier généré..
    Avez-vous bien placé toutes vos commandes dans un script SQL ?
    Si vous vous contentez de les copier coller dans SQL*Plus, vous n'aurez pas l'effet souhaité.

    Disons que votre script s'appelle DEMO.SQL.

    Vous devez faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sqlplus nom/mot_de_passe@entree_tnsnames @chemin\demo.sql
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  9. #9
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tchad

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2011
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Merci Pomalaix. La requête donne le résultat escompté. Sauf qu'à la fin il affiche le nombre des tuples renvoyées comme ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    107 ligne(s) sélectionnée(s).

  10. #10
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Pour traiter cet autre détail, il faut ajouter :
    SET FEEDBACK OFF

    Mais entre temps, vous l'avez probablement déjà trouvé...
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  11. #11
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tchad

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2011
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Merci Pomalaix. Je suis satisfait de votre aide si précieuse!!!

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

Discussions similaires

  1. Exécution automatique d'une requête
    Par sarah_ dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 17/10/2011, 15h55
  2. Réponses: 3
    Dernier message: 26/07/2009, 10h06
  3. Lors de l'ajout/supp d'un tuple : exécution auto d'une requête
    Par Tentative dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 02/01/2007, 18h08
  4. [Système] Exécution automatique d'une URL
    Par johnkro dans le forum Langage
    Réponses: 26
    Dernier message: 19/07/2006, 14h23
  5. exécution automatique d'une macro
    Par faayy dans le forum Access
    Réponses: 12
    Dernier message: 15/06/2005, 14h52

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