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

Administration Oracle Discussion :

Surveiller 'CREATE TABLE AS SELECT'


Sujet :

Administration Oracle

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 5
    Points : 4
    Points
    4
    Par défaut Surveiller 'CREATE TABLE AS SELECT'
    Bonjour,

    J'utilise une version Oracle database 9iR2...
    Via v$session et v$sqlarea, je peux récupérer les ordres SQL DML en cours
    d'exécution au sein de la base...
    Je voudrais aussi récupérer les ordres de type 'CREATE TABLE AS SELECT...'
    en cours d'exécution ou du moins les SELECT imbriqués dans les CREATE

    Est-ce possible ?
    Merci d'avance pour votre aide.

    MJag

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    tu peux faire un trigger ON SCHEMA

    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
    create or replace trigger ddl_trigger
    after create on SCHEMA
    begin
        insert into log
        select ora_sysevent,ora_dict_obj_owner,
               ora_dict_obj_name,ora_dict_obj_type,
               to_char(sysdate,'fm dd/Mon/yyyy HH:MI:SS AM'),
               machine,terminal,program,osuser
          from v$session
         where audsid = sys_context( 'userenv', 'sessionid' );
     
        if ( sql%rowcount <> 1 )
        then
            raise_application_error
            ( -20001, 'Unable to id your session' );
        end if;
    end;
    /

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Merci Fred pour avoir pris le temps de me répondre...

    Malheureusement le script fourni ne me donne pas l'information principale que
    je recherche c'est à dire l'ordre SELECT envoyé par l'application vers Oracle :

    Pour un CREATE TABLE AS SELECT....
    le SELECT exécuté est-il récupérable dans une des vues telles que v$sqlarea ?

    Mjag

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    Tu peux probablement récupérer le SELECT dans v$sqltext en jointure sur le SQL_HASH_VALUE de v$session.

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Fred,

    j'ai essayé cette piste mais lors de mes tests, l'ordre SQL associé n'est pas récupéré...
    Je vais poursuivre mes recherches

    Merci pour ta collaboration.

    Mjag

Discussions similaires

  1. CREATE TABLE .... AS SELECT
    Par blids dans le forum SQL
    Réponses: 5
    Dernier message: 13/10/2016, 14h00
  2. Create Table As (select Union Select )
    Par cactus2078 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 27/07/2009, 12h54
  3. Create table as select
    Par nexuspolaris dans le forum SQL
    Réponses: 2
    Dernier message: 01/10/2008, 08h58
  4. "create table x select" scanne toute ma table
    Par kagemaru dans le forum Requêtes
    Réponses: 3
    Dernier message: 22/11/2007, 21h47
  5. DELETE vs CREATE TABLE as SELECT
    Par beanl dans le forum Administration
    Réponses: 4
    Dernier message: 02/07/2007, 10h59

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