Précédent   Forum des professionnels en informatique > Bases de données > Langage SQL
Langage SQL Forum d'entraide sur le langage SQL et sur les questions liées à la conception de schéma (DDL). Cours SQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 28/01/2011, 17h48   #1
Invité régulier
 
Inscription : juillet 2007
Messages : 17
Détails du profil
Informations forums :
Inscription : juillet 2007
Messages : 17
Points : 6
Points : 6
Par défaut Clause Where sur une colonne renommée

Bonjour à tous,

Après moultes recherches, je ne trouve pas comment ou s'il est possible d'effectuer une clause where sur une colonne renommée.
L'exemple est le suivant :
Code :
1
2
3
4
5
6
7
8
9
 
SELECT
A
|| B
|| C
|| D
selection
FROM T1
HAVING selection LIKE '%Y%';
L'idée est d'avoir une concaténation d'un grand nombre de colonnes dont certaines sont des sous requêtes qui peuvent retourner Y.
Les reporter dans le WHERE est la solution alternative mais cette question me turlupine.

Merci pour votre lecture,
Michaël.
13mike est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/01/2011, 17h53   #2
Membre émérite
 
Inscription : août 2008
Messages : 835
Détails du profil
Informations forums :
Inscription : août 2008
Messages : 835
Points : 823
Points : 823
Bonjour,

Vous ne pouvez pas utiliser l'alias dans un WHERE.
Soit vous reportez l'expression dans le where, soit vous encapsulez votre requete dans une autre qui aura le filtre where.

Code :
1
2
3
4
5
6
7
8
9
10
11
12
SELECT selection 
FROM
(
 SELECT
     A
     || B
     || C
     || D
     selection
 FROM T1
)
WHERE selection LIKE '%Y%';
Et notez que HAVING ne s'utilise qu'en association avec un regroupement (GROUP BY).
Snipah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/01/2011, 17h53   #3
Modérateur
 
Homme Fabien
Ingénieur d'études en décisionnel
Inscription : septembre 2008
Messages : 5 684
Détails du profil
Informations personnelles :
Nom : Homme Fabien
Âge : 34
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études en décisionnel
Secteur : Arts - Culture

Informations forums :
Inscription : septembre 2008
Messages : 5 684
Points : 10 459
Points : 10 459
Envoyer un message via ICQ à Waldar Envoyer un message via Skype™ à Waldar
Non effectivement, vous ne pouvez pas utiliser les alias de colonne dans le WHERE.

Ça vient du fait que le parser SQL regarde le SELECT après le WHERE, et donc ne connaît pas encore les noms que vous avez donné.
__________________
Email : http://scr.im/waldar
Waldar est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/01/2011, 13h47   #4
Invité régulier
 
Inscription : juillet 2007
Messages : 17
Détails du profil
Informations forums :
Inscription : juillet 2007
Messages : 17
Points : 6
Points : 6
Bonjour,

Merci pour vos réponses, je vais traiter la question par encapsulation d'une sous requête.

A+
Michaël.
13mike est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h01.


 
 
 
 
Partenaires

Hébergement Web