Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
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 31/03/2008, 09h18   #1
Nouveau Membre du Club
 
Avatar de mbzhackers
 
Étudiant
Inscription : août 2005
Messages : 85
Détails du profil
Informations personnelles :
Âge : 30
Localisation : Tunisie

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : août 2005
Messages : 85
Points : 27
Points : 27
Par défaut Utiliser des ALIAS de colonnes dans une jointure

Bonjour tout le monde,

voilà j'aimerais utiliser une requête du genre :

Code :
1
2
3
4
SELECT A.CODE_MES, B.NUM_DOSS, GET_DEP(B.NUM_DOSS) AS "DEPOT"
FROM TABLE1 A, TABLE2 B
WHERE A.COD_MES = B.COD_MES
AND DEPOT='jkkkkj'
où GET_DEP est une fonction stockée, mais ça ne marche pas : j'ai un message d'erreur disant que DEPOT est un INVALID IDENTIFIER.

N'est-il donc pas possible d'utiliser un ALIAS de colonne dans une jointure ou bien je m'y suis mal pris ?

Merci d'éclairer ma lanterne.
__________________
LEGOLAS la classe
mbzhackers est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/03/2008, 09h36   #2
Membre éprouvé
 
Avatar de miloux32
 
Inscription : juillet 2003
Messages : 538
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 538
Points : 473
Points : 473
Citation:
Envoyé par mbzhackers Voir le message
Bonjour tout le monde,

voilà j'aimerais utiliser une requête du genre :

Code :
1
2
3
4
SELECT A.CODE_MES, B.NUM_DOSS, GET_DEP(B.NUM_DOSS) AS "DEPOT"
FROM TABLE1 A, TABLE2 B
WHERE A.COD_MES = B.COD_MES
AND DEPOT='jkkkkj'
où GET_DEP est une fonction stockée, mais ça ne marche pas : j'ai un message d'erreur disant que DEPOT est un INVALID IDENTIFIER.

N'est-il donc pas possible d'utiliser un ALIAS de colonne dans une jointure ou bien je m'y suis mal pris ?

Merci d'éclairer ma lanterne.
Ben justement il manque l'alias sur depot ....
__________________
C'est pas parce que ca marche que c'est bon!!
Pensez au bouton "Résolu"
Je ne réponds pas en privé aux questions
miloux32 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/03/2008, 09h55   #3
Nouveau Membre du Club
 
Avatar de mbzhackers
 
Étudiant
Inscription : août 2005
Messages : 85
Détails du profil
Informations personnelles :
Âge : 30
Localisation : Tunisie

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : août 2005
Messages : 85
Points : 27
Points : 27
Salut,

j'ai pas compris.

DEPOT c'est l'ALIAS de la colonne retournée par la fonction
GET_DEP(B.NUM_DOSS. Non ?
__________________
LEGOLAS la classe
mbzhackers est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/03/2008, 10h05   #4
Membre éprouvé
 
Avatar de miloux32
 
Inscription : juillet 2003
Messages : 538
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 538
Points : 473
Points : 473
Citation:
Envoyé par mbzhackers Voir le message
Salut,

j'ai pas compris.

DEPOT c'est l'ALIAS de la colonne retournée par la fonction
GET_DEP(B.NUM_DOSS. Non ?
Joker pardon j'ai super mal lu ....

Alors pour faire simple :
tu peux utiliser les alias de tables dans la clause WHERE
mais pas les alias de colonnes, ca me semble un non sens.

=> tu lui dis le résultat de "WHERE" s'appelle 'DEPOT'
mais tu utilises 'DEPOT' dans "WHERE"

Remplace par
Code :
1
2
3
4
SELECT A.CODE_MES, B.NUM_DOSS, GET_DEP(B.NUM_DOSS) AS "DEPOT"
FROM TABLE1 A, TABLE2 B
WHERE A.COD_MES = B.COD_MES
AND GET_DEP(B.NUM_DOSS) ='jkkkkj'
__________________
C'est pas parce que ca marche que c'est bon!!
Pensez au bouton "Résolu"
Je ne réponds pas en privé aux questions
miloux32 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/03/2008, 10h27   #5
Nouveau Membre du Club
 
Avatar de mbzhackers
 
Étudiant
Inscription : août 2005
Messages : 85
Détails du profil
Informations personnelles :
Âge : 30
Localisation : Tunisie

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : août 2005
Messages : 85
Points : 27
Points : 27
Oui j'ai déjà essayé ça mais en terme de performances c'est la cata : je pense que le fait d'exécuter la fonction 2 fois de suite en est la cause surtout si les 2 tables dont on parle font dans les 500 milles enregistrements.

En fait, j'ai trouvé une autre solution : j'ai bâti une vue sur cette requête

Code :
1
2
3
SELECT A.CODE_MES, B.NUM_DOSS, GET_DEP(B.NUM_DOSS) AS "DEPOT"
FROM TABLE1 A, TABLE2 B
WHERE A.COD_MES = B.COD_MES
Ensuite, dans ma FORM je définis un nouveau bloc de données ayant comme source de données la vue en question et dans la propriété DEFAULT WHERE du bloc je mais la 2ème condition de jointure ( DEPOT='jkkkkj' ).
Et ça marche , temps d'exécution 1 seconde !

Pourquoi ça marche pas en SQL natif alors que dans FORMS ça fonctionne, ça reste à voir.

Merci
miloux32 pour ton implication.
__________________
LEGOLAS la classe
mbzhackers 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 18h43.


 
 
 
 
Partenaires

Hébergement Web