Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-11-2007, 14:14   #1
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
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
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:20   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
Non ho capito molto, forse se posti il testo dell'esercizio e la struttura della tabella è + chiaro.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:21   #3
manu@2986
Senior Member
 
L'Avatar di manu@2986
 
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?
manu@2986 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:25   #4
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da manu@2986 Guarda i messaggi
"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?
guarda che nessun attributo è un sottoinsime di quelli del group (il sottoinsieme vuoto intendo)

Ultima modifica di nothinghr : 20-11-2007 alle 14:32.
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:27   #5
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Non ho capito molto, forse se posti il testo dell'esercizio e la struttura della tabella è + chiaro.
il testo non l'ho sottomano vado a memoria, comunque la query era banale, qui si tratta di un problema di correttezza dei risultati a dire del prof. a causa della sintassi che ho sopra riportato

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
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:40   #6
manu@2986
Senior Member
 
L'Avatar di manu@2986
 
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.
manu@2986 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:44   #7
lattone
Member
 
L'Avatar di lattone
 
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
lattone è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:44   #8
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da manu@2986 Guarda i messaggi
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.
Si questa è una cosa arcinota, ma lo capisci che qui è il problema inverso? Ovvero è anche vero il contrario, cioè che l'attributo che appare nel group deve essere nella select? Io non credo, o almeno è quello che ho trovato in esercizi presi da varie facoltà. Mi sono spiegato ora?
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:47   #9
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da lattone Guarda i messaggi
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
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.
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:54   #10
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
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/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 14:57   #11
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
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
Ecco, standard del '92 se non erro quindi? Mi domando soltanto perchè molti libri di testo parlano apertamente di sottoinsieme, e molti prof. svolgono query in quel senso.

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.
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:00   #12
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
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/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:04   #13
manu@2986
Senior Member
 
L'Avatar di manu@2986
 
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
Quote:
Originariamente inviato da nothinghr Guarda i messaggi
Si questa è una cosa arcinota, ma lo capisci che qui è il problema inverso? Ovvero è anche vero il contrario, cioè che l'attributo che appare nel group deve essere nella select? Io non credo, o almeno è quello che ho trovato in esercizi presi da varie facoltà. Mi sono spiegato ora?
" 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."

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.
manu@2986 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:06   #14
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
Magari serve a qualcuno
Codice:
http://www.contrib.andrew.cmu.edu/~shadow/sql/sql1992.txt
credo proprio che quella limitazione sia stata superata nelle versioni successive, ormai la domanda è, va bene non richiamarne alcuno, e vedo che nei forum ricorre questo dubbio, ho postato il problema perchè magari qualcuno si è già posto la domanda e a me serve solo una base certa per protestare

Ultima modifica di nothinghr : 20-11-2007 alle 15:08.
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:06   #15
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da manu@2986 Guarda i messaggi
" 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."

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.
io ho usato count(*) che è tutta un'altra cosa
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:13   #16
lattone
Member
 
L'Avatar di lattone
 
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
lattone è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:19   #17
manu@2986
Senior Member
 
L'Avatar di manu@2986
 
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.
manu@2986 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:20   #18
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da manu@2986 Guarda i messaggi
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.
ah no? e come le conti le prenotazioni in un determinato giorno?

certo puoi fare anche count(cod) ma è una scrittura simmetrica in questo caso

Ultima modifica di nothinghr : 20-11-2007 alle 15:25.
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:24   #19
nothinghr
Senior Member
 
L'Avatar di nothinghr
 
Iscritto dal: Mar 2002
Città: Firenze
Messaggi: 1091
Quote:
Originariamente inviato da lattone Guarda i messaggi
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
Forse non ho capito cosa intendi. Secondo il tuo ragionamento se faccio
select camera, count(*)
from prenotazioni
group by data, camera

non funziona? invece funziona eccome, pero' magari ho capito male cosa intendi...
nothinghr è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2007, 15:35   #20
manu@2986
Senior Member
 
L'Avatar di manu@2986
 
Iscritto dal: Aug 2003
Città: Biella
Messaggi: 692
Quote:
Originariamente inviato da nothinghr Guarda i messaggi
ah no? e come le conti le prenotazioni in un determinato giorno?

certo puoi fare anche count(cod) ma è una scrittura simmetrica in questo caso
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?
manu@2986 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
NASA: l'equipaggio di Crew-11 rientrer&a...
CoopVoce lancia le sue prime offerte 5G:...
Rivoluzione The Elder Scrolls Online: un...
Lo strapotere cinese è evidente c...
GeForce RTX 6000: niente SUPER e attesa ...
Anche gli Stati Uniti puntano il dito co...
È cinese la prima (enorme) pala e...
A Pechino è record di giorni con ...
Lenovo al CES 2026: Qira, IA ambientale ...
Le sette startup italiane che ridefinisc...
Philips Hue SpatialAware: la configurazi...
Sport & Lifestyle: performance, dati...
Le novità HP al CES 2026 tra AI P...
Gigabyte propone OLED per tutti con lumi...
Musk contro OpenAI, la guerra arriva in ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:22.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v