|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
[MYSQL] SELECT DELLA STESSA COLONNA 2 VOLTE IN 1 QUERY
ragazzi, volevo chiedervi se fosse possibile fare una select di una stessa colonna due volte con parametri diversi. Tipo:
select nome, nome from squadra where condizione and altracondizione la mia idea è quella di usare una alias o qualcosa del genere. Ma non so se è proprio possibile farlo. qualcuno che mi ILLUMINI...
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
|
Non ho un mysql velocemente raggiungibile, ma se la memoria non mi tradisce, questo dovrebbe essere standard (su oracle funziona almeno...)
Codice:
select dummy as "O' rly?", dummy as "Ya, rly" from dual
__________________
-> The Motherfucking Manifesto For Programming, Motherfuckers |
|
|
|
|
|
#3 |
|
Member
Iscritto dal: Apr 2005
Città: Campagnola Emilia
Messaggi: 202
|
Certo che è possibile...
__________________
"L'informatica è come la fisica.La differenza è che mentre la fisica è governata da leggi naturali, in informatica sei tu il creatore. All'interno del computer puoi essere un Dio." Linus Torvalds |
|
|
|
|
|
#4 | |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
Quote:
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
|
#5 |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
|
Quote:
No non puoi, a meno che tu non faccia una join con la tabella stessa, tipo... Codice:
select t1.a as "A1", t2.a as "A2" from tab t1 join tab t2 on ...qualcosa... where t1.a = ...qualcosa... and t2.a = ...qualcosa...
__________________
-> The Motherfucking Manifesto For Programming, Motherfuckers |
|
|
|
|
|
|
#7 |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
il join penso proprio che sia fondamentale...provo a spiegarti il problema cn questo esempio perchè non penso sia la soluzione che serve a me quella che mi hai gentilmente proposto tu:
io ho una tabella squadre dove ho 2 colonne rispettivamente id_squadra e nome squadra. poi ho una tabella partita dove ho l'id_partita. queste due tabelle sono relazionate ad una terza tabella gioca. dove ho l'id_partita di partita e id_squadra (2 volte) che mi rappresenta appunto l'incontro associato. ora io attraverso una select vorrei stampare dalla tabella gioca i nomi delle squadre che si affronteranno. il gioco dei join mi è chiaro, ma nella select cosa richiamo? Un altra soluzione è fare due volte la select una per esempio per le squadre che per quel turno figurano in casa l'altro per le squadre che per quel turno figurano in trasferta. ma siccome non ho esigenze mi sono permesso di avere questo dubbio. concludo dicendo che neanche sul manuale ho trovato qualcosa di utile x me
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
|
Quote:
__________________
-> The Motherfucking Manifesto For Programming, Motherfuckers |
|
|
|
|
|
|
#9 |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
due volte nella stessa select? e a che serve?
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
#10 |
|
Member
Iscritto dal: Aug 2011
Messaggi: 112
|
In questo momento non ho a disposizione un server per controllare ma dovrebbe essere qualcosa del tipo:
SELECT TeamHome.NomeSquadra, "VS", TeamAway.NomeSquadra FROM (Squadre AS TeamHome INNER JOIN Incontri ON TeamHome.idSquadra=Incontri.Squadra1) INNER JOIN Squadre AS TeamAway ON Incontri.Squadra2=TeamAway.idSquadra Incontri è la tabella che relaziona Squadre e Partite(non di interesse per questa query). Per una maggior chiarezza ho esplicitato i campi della tabella Incontri anche se non è richiesto, avendo suddetti campi necessariamente intestazioni differenti. Ultima modifica di sirHydra : 29-08-2011 alle 20:05. |
|
|
|
|
|
#11 | |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
Quote:
Domando giusto per curiosità, anche se questa soluzione è ottima, ma senza alias si poteva fare? io penso di no...
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
|
#12 |
|
Member
Iscritto dal: Aug 2011
Messaggi: 112
|
Figurati
Senza alias sarebbe un bell'esperimento A naso no, perchè per la selezione finale ci sarebbe un'ambiguità sul campo nomeSquadra. I 2 join sulla stessa tabella infatti creano un tabellone contenente i duplicati di tutti i campi di Squadra. |
|
|
|
|
|
#13 | |
|
Member
Iscritto dal: Dec 2010
Messaggi: 74
|
Quote:
Ancora grazie...e ovviamente grazie anche a tutti gli altri
__________________
Scheda Madre : Asus P6T SE | Chipset : Intel X58 | Processore : Intel Core i7 920 @ 2666MHz | Memoria Fisica : 6144MB (3 x 2048 DDR3-SDRAM ) | Scheda Video : ATI Radeon HD 4890 Series | Hard Disk : Seagate STM3500418AS ATA Device (500GB) | DVD-Rom Drive : Optiarc DVD RW AD-7240S | Tipo Monitor : Nissei Sangyo L5AK6 - 15 pollici |
|
|
|
|
|
|
#14 |
|
Member
Iscritto dal: Aug 2011
Messaggi: 112
|
Eccooolà
Una nota: ho editato sistemando la condizione sulla clausula ON del primo JOIN perchè nella fretta mi sono accorto di aver invertito i riferimenti posizionali campo-tabella richiesti. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 13:19.




















