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 :

[SQL]Retour d'une colonne unique


Sujet :

Oracle

  1. #1
    Futur Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 23
    Points : 6
    Points
    6
    Par défaut [SQL]Retour d'une colonne unique
    Bonjour,

    Je suis face à un jeu de données du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Période  Agent  Code  Libellé du code
    -------  -----  ----  --------------
    1        1      A     Libellé A
    1        2      Z     Libellé Z
    1        3      H     Libellé H
    1        4      A     Libellé A
    2        1      U     Libellé U
    2        2      K     Libellé K
    2        5      A     Libellé A...
    En gros, j'ai unicité, sur la période et du code par rapport à son libellé. Si je veux obtenir le libellé pour un Code, et que je veux une seule occurence de la réponse, je dois utiliser le mot 'DISTINCT' ... Mais ce n'est pas optimal

    Y'aurait'il une fonction SQL/spécifique Oracle pour stopper la requête dès que le SGBDR trouve une occurence de mon code et peut ainsi me renvoyer le libellé correspondant ???

    Merci

  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 : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT code, libellé 
    FROM ( SELECT code, libellé, RANK () OVER (ORDER BY code) rang FROM tab )
    WHERE rang = 1

  3. #3
    Futur Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 23
    Points : 6
    Points
    6
    Par défaut
    Ouah ... Je teste ... Mais c'est mortel cette réponse

  4. #4
    Futur Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 23
    Points : 6
    Points
    6
    Par défaut
    Je n'ai pas réussi à faire fonctionner cette commande comme je le voulais

    Par contre, un collègue m'a rappelé l'existance de la pseudo-colonne ROWNUM. L'ordre suivant répond parfaitement à ma demande ... Full Scan des valeurs, jusqu'à ce qu'une valeure corresponde puis fin du processus :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT code,libelle FROM tab WHERE code='ZOUP' AND ROWNUM < 2;
    Merci pour ton aide

  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 : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    mais là tu ne retournes qu'une seule ligne alors que le RANK c'est une ligne par code

    pour plus d'infos : http://lalystar.developpez.com/fonct...lytiques/#L3.8

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 26/12/2007, 11h00
  2. Réponses: 10
    Dernier message: 02/02/2007, 01h02
  3. Réponses: 6
    Dernier message: 15/12/2005, 15h29
  4. PL/SQL retour d'une fonction
    Par aaronw dans le forum PL/SQL
    Réponses: 2
    Dernier message: 13/12/2005, 14h25
  5. Instruction SQL qui supprime une colonne d'une table
    Par tseg dans le forum Langage SQL
    Réponses: 2
    Dernier message: 31/10/2003, 21h47

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