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 05/02/2012, 10h34   #1
Invité de passage
 
Inscription : mai 2008
Messages : 11
Détails du profil
Informations forums :
Inscription : mai 2008
Messages : 11
Points : 0
Points : 0
Par défaut Problème avec alias (AS)

hello le monde,

voila j'utilise la commande suivante pour faire une jointure:

Code :
1
2
3
4
5
6
7
8
SELECT *
FROM maTableA
LEFT JOIN maTableB ON maTableA.id = maTableB.uid
WHERE maCondition = (
SELECT maSelection
FROM maTableC
WHERE XYZ = 'lorem ipsum' )
LIMIT 0 , 5
Ca fonctionne très bien mais le problème est que mysql me renvoit un tableau qui est pas facilement manipulable depuis PHP du fait qu'il peut y avoir deux fois la colonne "ID" par exemple.

D'après mes recherche la solution se trouve dans les alias. Du coup je fabrique ceci (qui fonctionne aussi et qui RESOUD le problème):

Code :
1
2
3
4
5
6
7
8
SELECT A.id AS 'blabla', A.colonne2 AS 'blab' ............
FROM maTableA A
LEFT JOIN maTableB B ON A.id = B.uid
WHERE maCondition = (
SELECT maSelection
FROM maTableC
WHERE XYZ = 'lorem ipsum' )
LIMIT 0 , 5
Le seul problème est que le select devient hyper hyper long car ma table est assez longue. N'es t il pas possible de dire a mysql qu'il me revoit tout les champ avec un préfixe ? Avec une commande comme ceci:

J'espère que je me suis bien expliquer car ce n'est pas facile... Merci
jeanpierre215 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 12h02   #2
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 11 029
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations professionnelles :
Activité : Ingénieur d'études en informatique
Secteur : Enseignement

Informations forums :
Inscription : août 2006
Messages : 11 029
Points : 18 331
Points : 18 331
Envoyer un message via MSN à CinePhil
1) Il faut éviter de ranimer la guerre des étoiles !

2) Plutôt que le WHERE avec une sous requête corrélée, pourquoi ne pas faire une seconde jointure ?
__________________
Philippe Leménager. Ingénieur d'étude à l'École Nationale de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
À la maison comme au bureau, j'utilise Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 05/02/2012, 16h43   #3
Membre actif
 
Inscription : janvier 2012
Messages : 117
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 117
Points : 173
Points : 173
D'accord avec Cinephil, autant avoir une requête claire dont on sait ce qu'elle renvoie, que des SELECT *. Cela facilitera la maintenance...
Autre remarque, peux tu faire sans le LIMIT? Je ne vois pas de ORDER BY dans ta requête, donc comment connais tu les premiers enregistrements retournés?
KookieMonster est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 23h28   #4
Invité de passage
 
Inscription : mai 2008
Messages : 11
Détails du profil
Informations forums :
Inscription : mai 2008
Messages : 11
Points : 0
Points : 0
CinePhil>
1) Thx, après avoir lu cette page je comprend mieux pourquoi il ne vaudrai mieux ne pas utiliser le *. Néanmoins a titre d'info, es t il possible de faire ce que je demandais ? CAD une sorte de SELECT * AS 'prefixA_' .

2) Je ne comprend pas bien la, selon moi le WHERE est obligatoire ? Comment tu ferait ca sinon ?

KookieMonster>
Le LIMIT est obligatoire dans mon cas .... faudrait t il le faire sans ? si oui, pk ?
Par contre c'est vrai que j'ai oublier ORDER BY.... THX
jeanpierre215 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/02/2012, 00h17   #5
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 11 029
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations professionnelles :
Activité : Ingénieur d'études en informatique
Secteur : Enseignement

Informations forums :
Inscription : août 2006
Messages : 11 029
Points : 18 331
Points : 18 331
Envoyer un message via MSN à CinePhil
Citation:
Envoyé par jeanpierre215 Voir le message
CinePhil>
1) Thx, après avoir lu cette page je comprend mieux pourquoi il ne vaudrai mieux ne pas utiliser le *. Néanmoins a titre d'info, es t il possible de faire ce que je demandais ? CAD une sorte de SELECT * AS 'prefixA_' .
Pas à ma connaissance.
En plus, maintenant que tu as compris que ce n'est pas bien de vouloir le faire...

Citation:
2) Je ne comprend pas bien la, selon moi le WHERE est obligatoire ? Comment tu ferait ca sinon ?
Ben avec des abstractions "matableA", "matableB", "macondition", difficile de comprendre précisément ce que tu cherches à faire mais d'une manière générale, une requête corrélée est souvent remplaçable par une jointure qui est beaucoup plus efficace.
__________________
Philippe Leménager. Ingénieur d'étude à l'École Nationale de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
À la maison comme au bureau, j'utilise Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/02/2012, 14h09   #6
Membre actif
 
Inscription : janvier 2012
Messages : 117
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 117
Points : 173
Points : 173
Pour le limit, ce n'est pas une opération ensembliste et elle ne fait pas partie des normes SQL. Quand tu l'utilises (arrêtez moi si je dis des bêtises), tu t'en remets à ton SGBD pour savoir quelles lignes il va bien pouvoir te renvoyer. Sur un autre implémentant cette fonction, le résultat serait peut-être différent.
KookieMonster est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



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


 
 
 
 
Partenaires

Hébergement Web