|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 | ||
|
Member
Iscritto dal: Feb 2005
Messaggi: 127
|
[SQL] una domandina sul group by
ragazzi ho questa query:
Quote:
Codice:
SELECT relazione.titolo, COUNT(*) FROM presentazione JOIN stesura ON (presentazione.relazione = stesura.relazione) JOIN relazione ON (presentazione.relazione = relazione.codice) JOIN autore ON (stesura.autore = autore.nome) WHERE autore.nazione = 'italia' GROUP BY relazione.codice, relazione.titolo Io mi chiedevo questa domanda: Quote:
edit: queste sono le tabelle: Codice:
create table autore( nome varchar(20) primary key not null, istituzione varchar(20) not null, nazione varchar(20) not null ) without oids; create table relazione( codice int primary key not null, titolo varchar(20) not null )without oids; create table stesura( autore varchar(20) not null references autore(nome) on delete cascade on update restrict, relazione int not null references relazione(codice) on delete cascade on update restrict, primary key(autore, relazione) )without oids; create table coordinatore( nome varchar(20) primary key not null, sessione varchar(20) unique not null )without oids; create table presentazione( relazione int primary key not null references relazione(codice) on delete cascade on update restrict, autore varchar(20) not null references autore(nome) on delete cascade on update restrict, sessione varchar(20) not null references coordinatore(sessione) on delete cascade on update restrict )without oids;
__________________
the AUSTRALOPITECI |
||
|
|
|
|
|
#2 |
|
Member
Iscritto dal: Feb 2005
Messaggi: 127
|
up
__________________
the AUSTRALOPITECI |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
|
Io proverei a risolvere così, anche se, lo ammetto, non è efficientissima:
Codice:
SELECT relazione.titolo, COUNT(*)
FROM stesura JOIN relazione ON (stesura.relazione = relazione.codice)
JOIN autore ON (stesura.autore = autore.nome)
WHERE autore.nazione = 'francia' AND relazione.codice IN
(SELECT relazione.codice
FROM presentazione JOIN stesura ON (presentazione.relazione =
stesura.relazione)
JOIN relazione ON (presentazione.relazione = relazione.codice)
JOIN autore ON (stesura.autore = autore.nome)
WHERE autore.nazione = 'italia')
GROUP BY relazione.codice, relazione.titolo
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN Ultima modifica di Mixmar : 15-02-2006 alle 22:22. |
|
|
|
|
|
#4 |
|
Member
Iscritto dal: Feb 2005
Messaggi: 127
|
k grazie mille
ora vedo se riesco a fare di meglio
__________________
the AUSTRALOPITECI |
|
|
|
|
|
#5 |
|
Member
Iscritto dal: Oct 2005
Messaggi: 65
|
Per avere la stessa query con gli autori francesi basta cambiare la nazione in 'francia' immagino.
Alternativamente, con questa query: Codice:
SELECT autore.nazione, relazione.titolo, COUNT(*) FROM presentazione JOIN stesura ON (presentazione.relazione = stesura.relazione) JOIN relazione ON (presentazione.relazione = relazione.codice) JOIN autore ON (stesura.autore = autore.nome) GROUP BY autore.nazione, relazione.codice, relazione.titolo Ciao |
|
|
|
|
|
#6 | ||
|
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
|
Quote:
Quote:
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
||
|
|
|
|
|
#7 |
|
Member
Iscritto dal: Oct 2005
Messaggi: 65
|
mmh... mi era scappata una condizione
Si, la tua soluzione mi sa che e' la migliore. Rileggendo meglio avevo ipotizzato si potesse fare in maniera piu' efficiente con una subquery dentro la FROM, boh forse e' fattibile ma ora come ora non mi e' venuto in mente nulla. Forse spremendosi un po'.... |
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
|
Quote:
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 15:29.



















