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 :

[SQL] Sélection par numéro de colonne


Sujet :

SQL Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2007
    Messages
    26
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 26
    Points : 24
    Points
    24
    Par défaut [SQL] Sélection par numéro de colonne
    Bonjour,

    Je suis en train de coder une procédure en PL/SQL, et je voulais savoir s'il était possible d'écrire une requête SELECT qui ne retournerait que la n-ième colonne d'une table.
    L'objectif étant de lui passer en paramêtre le numéro de la colonne voulue, et non son nom.

  2. #2
    Membre régulier
    Inscrit en
    Septembre 2005
    Messages
    73
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 73
    Points : 82
    Points
    82
    Par défaut
    Bonjour,

    Peut être avec column_id

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select table_name, column_name, column_id from user_tab_columns

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2007
    Messages
    26
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 26
    Points : 24
    Points
    24
    Par défaut
    Hmm, non ça ne marche pas.

    L'objectif du truc c'est de savoir s'il existe une fonction du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT numcolonne(2) FROM matable;
    pour ne sélectionner que la deuxième colonne.

    Je fais ceci car je souhaite que la procédure que je suis en train de programmer soit la plus générique possible et donc je ne souhaite pas utiliser les noms de colonnes...

  4. #4
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 307
    Points
    5 307
    Par défaut
    Bon, un petit exemple pour démontrer le propos :

    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
    41
     
    set serveroutput on;
     
    DECLARE
        TYPE cur is REF CURSOR;
        v_idx number;
        v_table varchar2(100);
        v_sql varchar2(512);
        v_col varchar2(50);
        v_res varchar2(100);
        v_cur cur;
    BEGIN
     
        -- index de la colonne à rechercher
        v_idx   := 2;
     
        -- nom de la table
        v_table := 'PLAT2';
     
        -- recherche du nom de colonne dans le catalogue
        v_sql := 'select column_name from cols where table_name = upper(''' || v_table || ''') and column_id = ' || v_idx;
     
        EXECUTE IMMEDIATE v_sql INTO v_col;
     
        -- selection du champs de la table
        v_sql := 'select ' || v_col || ' from ' || v_table;
     
        -- fetch du curseur et affichage des valeurs
        OPEN v_cur for v_sql;
     
        LOOP
            FETCH v_cur INTO v_res;
            EXIT WHEN v_cur %NOTFOUND;
     
            dbms_output.put_line(v_res);    
     
        END LOOP;
     
        CLOSE v_cur;
    end;
    /
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2007
    Messages
    26
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 26
    Points : 24
    Points
    24
    Par défaut
    Ah d'accord!

    Merci pour l'explication

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

Discussions similaires

  1. [2005] SQL: sélection d'un échantillonage par jointure
    Par winter60 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 11/04/2014, 15h00
  2. Réponses: 5
    Dernier message: 11/06/2013, 22h03
  3. Editeur de texte qui fait la sélection par colonne
    Par wodel dans le forum Windows XP
    Réponses: 5
    Dernier message: 10/11/2010, 13h45
  4. Colonne par numéro
    Par Gamal le Celte dans le forum Langage SQL
    Réponses: 6
    Dernier message: 11/09/2008, 12h30
  5. [T-SQL] Connaître le nombre de colonnes retourner par une PS
    Par NeoMan dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 28/12/2005, 11h30

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