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

Langage SQL Discussion :

SQL: colonnes virtuelles


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Par défaut SQL: colonnes virtuelles
    Salut,

    J'ai besoin d'aide pour une requête, voici l'énoncé du problème:

    BDD: PostgreSQL

    J'ai une table tbl contenant une colonne A, de type integer. Je souhaite afficher simultanément 3 colonnes que nous appellerons B,C et D, affichant les valeurs x contenues dans A, comme suit:
    - B: x =< 100
    - C: 100 < x =< 500
    - D: x > 500

    Rien de bien compliqué jusque là. Je souhaite cependant le faire sans créer de table temporaire. L'idéal serait une vue. J'ai sinon pensé à créer 3 colonnes additionnelles dans la table tbl et de les mettre à jour avant chaque affichage, mais je trouve ça un peu lourd.

    Je précise, pour lever toute ambiguité, que les colonnes B,C et D n'existent que virtuellement.

    Quelqu'un a une idée ?

  2. #2
    Membre Expert Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Par défaut
    Ce genre de requete peut vous aider :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    select a, 
           case when (a<=100) then a else null end as b,
           case when (a<=500 and a>100) then a else null end as c,
           case when (a>500) then a else null end as d
           from matable
    A tester et adapter

    Bon courage

  3. #3
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Par défaut
    Splendide, c'est exactement ce que je cherchais

    Merci !

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

Discussions similaires

  1. [MySQL] Requete SQL colonne virtuelle qui s'incrémente
    Par Gingirou dans le forum PHP & Base de données
    Réponses: 14
    Dernier message: 12/03/2011, 17h09
  2. [T-SQL] Colonnes d'une table appelées avec une variable
    Par Deedoo2000 dans le forum Adaptive Server Enterprise
    Réponses: 3
    Dernier message: 25/09/2006, 15h18
  3. [Sql] colonnes d'une table
    Par atanabe dans le forum Oracle
    Réponses: 3
    Dernier message: 03/08/2006, 09h08
  4. [PL/SQL] Machine virtuelle
    Par patmaba dans le forum Oracle
    Réponses: 8
    Dernier message: 22/01/2006, 22h57
  5. Réponses: 15
    Dernier message: 22/07/2005, 09h49

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