Téléchargement
illégal
Posez votre question Signaler

[SQL]Utilisation de CASE ou DECODE

batitou81 - Dernière réponse le 22 juil. 2010 à 15:13
Bonjour tout le monde,
Je souhaiterais effectuer une requete SQL, mais je suis bloqué. Voici une partie de ma requete
SELECT CASE job_id
WHEN 'admin' THEN 2
WHEN 'manager' THEN 1
END post, salaire
FROM work;
Et en fait, je souhaiterais pouvoir réutiliser dans le même SELECT la colonne que j'ai crée qui s'appel "post", par exemple quand j'essai de la réecrire simplement ( c'est à dire ..END post, salaire, post), ça me retourne l'erreur
"POST" invalid identifier.
Quelqu'un aurait une idée de comment la réutiliser, sans refaire le CASE ?
Lire la suite 

[SQL]Utilisation de CASE ou DECODE »

7 réponses
Réponse
+3
moins plus
essaye

SELECT
CASE job_id
WHEN 'admin' THEN 2
WHEN 'manager' THEN 1
END as post,
salaire
FROM work;
Ajouter un commentaire
Réponse
+1
moins plus
j'ai une colonne classif qui contient les valeurs ('A1', 'A2', 'A3', 'A4', 'B1', 'B2', 'B3', 'B4', 'C1', 'C2', 'C3', 'C4', 'D1', 'D2', 'D3', 'D4', 'A5', 'A8', 'B5', 'B8', 'C5', 'C8', 'D5', 'D8')
une colonne client_id et ma table s'appelle coface_clients
je voudrais arriver à regrouper les donnees classif een deux types de catégories
Dinheru- 18 juin 2008 à 11:57
Tu devrais y arriver en tapant une requète de ce type :

Select client_id,
Case
When classif in ('A5' , 'A8' , 'B5' , 'B8' , 'C5' , 'C8' , 'D5' , 'D8')
Then 'Inactif'
Else 'Actif'
End as Etat_Client
From coface_clients
Where 1

Voila en espérant t'avoir aidé ^^
beauxoeil - 18 juin 2008 à 12:09
merci beaucoup ça marche par contre j'ai enlevé le Where 1
par qu'il me met ce message d'erreur "Expression de type non booléen spécifiée dans un contexte où une condition est attendue, près de '1'"
Ajouter un commentaire
Réponse
-1
moins plus
Je travaille sur une requête mais j’ai des petits soucis. qui est ce qui pourrait me dépanner ?
Voici mon problème :
J’ai des clients en classification ('A1', 'A2', 'A3', 'A4', 'B1', 'B2', 'B3', 'B4', 'C1', 'C2', 'C3', 'C4', 'D1', 'D2', 'D3', 'D4') ce sont les 'CLIENTS_ACTIFS'
des clients en classif ('A5', 'A8', 'B5', 'B8', 'C5', 'C8', 'D5', 'D8') qui sont les 'CLIENTS_INACTIFS'.
Je voudrais savoir si vous connaissez une astuce pour créer dans ma requête une colonne ‘CATEGORIE’ qui va classer les clients en Actifs, inactifs.
Merci d’avance
Dinheru- 18 juin 2008 à 11:33
Bonjour,

Je pense que c'est faisable mais pourais-tu me donner un descriptif de ta table : nom et champs qui la compose ?
ça sera plus facile pour te donner un exemple de requète.
youyouy - 22 juil. 2010 à 15:13
Select client_id,
Case
When classif in ('A5', 'A8', 'B5', 'B8', 'C5', 'C8', 'D5', 'D8')
Then 'CLIENTS_INACTIFS'
Else 'CLIENTS_ACTIFS'
End as CATEGORIE
From Table_clients
Ajouter un commentaire
Ce document intitulé « [SQL]Utilisation de CASE ou DECODE » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?