|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Domandona SQL
Qualcuno mi sa spiegare perchè la seguente parte di query potrebbe causare risultati scorretti?
.... Select count(*) from prenotazioni group by data .... Mi è stata corretta nell'esame di Basi di Dati perchè pare che nella target list ci dovrebbe essere data, ma questa cosa mi suona nuova dato che comunque nella select ci deve sempre essere un sottinsieme degli attributi del group. In particolare poi ne devo fare una media e chi me l'ha corretta sostiene che si potrebbero avere il raggruppamento di righe distinte avente lo stesso valore di count(*)... boh |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2780
|
Non ho capito molto, forse se posti il testo dell'esercizio e la struttura della tabella è + chiaro.
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
|
"nella select ci deve sempre essere un sottinsieme degli attributi del group."
Forse non ho capito bene, ma se è come dici tu ti sei risposto da solo, nel select non c'è un sottoinsieme degli attributi del group by, anzi, è il contrario. Comunque, a parte questo, mi pare di ricordare che quando facevo le interrogazioni con access nel campo select dovevo specificare sempre lo stesso attributo (o gli stessi) che usavo nella clausola group by, e usando * mi dava errore. Comunque potresti postare il testo esatto dell'interrogazione? |
|
|
|
|
|
#4 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
Ultima modifica di nothinghr : 20-11-2007 alle 14:32. |
|
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
Comunque cerco di essere piu' chiaro: ho una tabella in cui ho delle prenotazioni in cui il codice è la chiave li raggruppo per data, li conto e poi nella select principale faccio avg(risultato_vista), impostando la vista come sopra. Il problema a quanto pare è sottile infatti la query è sintatticamente corretta |
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
|
Direttamente dal mio libro di basi di dati:
Ogni colonna che appare nella lista-select deve anche apparire nella lista-gruppo. La ragione è che ogni riga del risultato dell'interrogazione corrisponde a un gruppo, che è una collezione di righe aventi, nelle colonne menzionate in lista-gruppo, gli stessi valori. In generale, se una colonna appare nella lista-select ma non nella lista-gruppo, possono esserci diverse righe all'interno di un gruppo che in quella colonna hanno valori diversi, e non è chiaro quale di questi valori dovrebbe essere assegnato, nella risposta, alla colonna stessa. |
|
|
|
|
|
#7 |
|
Member
Iscritto dal: Sep 2001
Città: pisa
Messaggi: 70
|
Tu hai chiesto al compilatore di raggruppare per data una tabella in cui non hai selezionato nessun attributo data.
In questi casi compilatori e professori si comportano alla stessa maniera |
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
|
|
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Che discorso è, l'attributo per cui raggruppi non deve essere necessariamente nella select, è vero il contrario
Ultima modifica di nothinghr : 20-11-2007 alle 14:53. |
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Sep 2007
Messaggi: 754
|
The SQL92 standard required that any column referred to in the "group by" must also be specified in the "select" list (among other restrictions).
Secondo lo standard i campi della group by sono richiesti nella selct list
__________________
http://www.tevigroup.it/ |
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
Quello che segue è preso ad esempio dai lucidi dell'università di Parma: In ogni interrogazione che usa group by, argomento della select (escludendo l’operatore aggregato) può essere solo un sottoinsieme degli attributi usati nella clausola group by. il che cozza con quell oche dice lo standard che hai postato Ultima modifica di nothinghr : 20-11-2007 alle 15:00. |
|
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Sep 2007
Messaggi: 754
|
Magari serve a qualcuno
Codice:
http://www.contrib.andrew.cmu.edu/~shadow/sql/sql1992.txt
__________________
http://www.tevigroup.it/ |
|
|
|
|
|
#13 | |
|
Senior Member
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
|
Quote:
Ora, tu nella select hai usato * che ti prende tutti gli attributi della tabella, e nel group by hai usato solo data, quindi siamo nel caso che ho scritto qua sopra. |
|
|
|
|
|
|
#14 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
Ultima modifica di nothinghr : 20-11-2007 alle 15:08. |
|
|
|
|
|
|
#15 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
|
|
|
|
|
|
|
#16 |
|
Member
Iscritto dal: Sep 2001
Città: pisa
Messaggi: 70
|
Prova ad disegnare l'albero di interrogazione (o come si chiama) della tua query.
{ groupby(data) } | { select{count() } | { from(prenotazioni) } da leggere dal basso verso l'alto group by lavora sul risultato della select |
|
|
|
|
|
#17 |
|
Senior Member
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
|
ok allora mettiamola così, cosa ti serve portarti dietro tutti gli attributi della tabella per poi calcolarne la media, non ti basta raggruppare per la data? Ammesso che sia giusto come dici tu, anche se non ne sono convinto, che motivo c'è di fare count(*)? nessuno.
|
|
|
|
|
|
#18 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
certo puoi fare anche count(cod) ma è una scrittura simmetrica in questo caso Ultima modifica di nothinghr : 20-11-2007 alle 15:25. |
|
|
|
|
|
|
#19 | |
|
Senior Member
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
|
Quote:
select camera, count(*) from prenotazioni group by data, camera non funziona? invece funziona eccome, pero' magari ho capito male cosa intendi... |
|
|
|
|
|
|
#20 |
|
Senior Member
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
|
Appunto quello che intendevo, quindi se avessi fatto così il prof avrebbe detto che era sbagliato, ma, in sostanza, come la vuole il prof sta interrogazione?
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 16:33.




















