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 :

Liste des colonnes d'une vue


Sujet :

SQL Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 21
    Points : 23
    Points
    23
    Par défaut Liste des colonnes d'une vue
    J'ai cherché sur le net, sur la faq, sur le forum, mais je trouve que la façon pour lister les champs d'une table

    mais, moi, j'ai besoin de lister la liste des colonnes d'une vue sous oracle!!

    Merci de me donner la requete Sql à utiliser

  2. #2
    Membre expérimenté Avatar de scheu
    Inscrit en
    Juin 2007
    Messages
    1 506
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 1 506
    Points : 1 734
    Points
    1 734
    Par défaut
    Les vues sont aussi dans la vue dba_tab_columns, il suffit donc de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM dba_tab_columns WHERE OWNER = 'TON_SCHEMA' and table_name = 'TA_VUE'
    La théorie, c'est quand on sait tout mais que rien ne fonctionne.
    La pratique, c'est quand tout fonctionne mais que personne ne sait pourquoi.
    Ici, nous avons réuni théorie et pratique : Rien ne fonctionne ... et personne ne sait pourquoi !

    Réplication de base avec Postgresql : http://scheu.developpez.com/tutoriel.../log-shipping/

  3. #3
    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 ne peux pas, inspire toi de ce sujet : http://www.developpez.net/forums/sho...CRIBE_COLUMNS2
    avec la requête récupérée dans dba_views.

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 21
    Points : 23
    Points
    23
    Par défaut
    Merci

    Sinon, on peut également utiliser celle là :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM ALL_COL_COMMENTS where TABLE_NAME = 'NOM_VUE'

  5. #5
    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
    Regarde :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SQL>create table mytab (id integer, name varchar2(10));
     
    Table created.
     
    SQL>create view myview as SELECT * FROM mytab;
     
    View created.
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    SET SERVEROUTPUT ON
    declare
      stmt VARCHAR2(32000);
      c number;
      d number;
      col_cnt integer;
      f BOOLEAN;
      rec_tab dbms_sql.desc_tab2;
      rec_desc dbms_sql.desc_rec2;
      col_num number;
    begin
      c := dbms_sql.open_cursor;
      SELECT TEXT  
      INTO stmt 
      FROM dba_views
      WHERE VIEW_NAME='MYVIEW';
      dbms_sql.parse(c,stmt, DBMS_SQL.NATIVE);
     
      d := dbms_sql.execute(c);
     
      dbms_sql.describe_columns2(c, col_cnt, rec_tab);
     
    /*
     * Following loop could simply be for j in 1..col_cnt loop.
     * Here we are simply illustrating some of the PL/SQL table
     * features.
     */
      col_num := rec_tab.first;
      IF (col_num IS NOT NULL) then
        loop
        dbms_output.put_line('col_name            =    '
                             || rec_tab(col_num).col_name);
          col_num := rec_tab.next(col_num);
          exit when (col_num IS NULL);
        end loop;
      end IF;
     
      dbms_sql.close_cursor(c);
    end;
    /
    col_name = ID
    col_name = NAME

    PL/SQL procedure successfully completed.

  6. #6
    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
    Citation Envoyé par chaouki_2000 Voir le message
    Merci

    Sinon, on peut également utiliser celle là :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM ALL_COL_COMMENTS where TABLE_NAME = 'NOM_VUE'
    c'est beaucoup plus simple en effet

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

Discussions similaires

  1. Liste des tables d'une vue
    Par wazoo333 dans le forum Oracle
    Réponses: 6
    Dernier message: 24/02/2012, 09h54
  2. [MySQL] Liste des colonnes d'une table
    Par totoAussi dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 09/08/2009, 17h40
  3. Comment rendre dynamique les noms des colonnes d'une vue
    Par patic dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 16/02/2009, 10h41
  4. Liste des colonnes d'une requête
    Par romuald07 dans le forum PL/SQL
    Réponses: 5
    Dernier message: 05/08/2008, 17h24
  5. Recuperer la liste des colonnes d'une table
    Par miai85 dans le forum Oracle
    Réponses: 1
    Dernier message: 12/07/2007, 11h44

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