Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Realizzato da Lenovo e installato presso il Cineca di Casalecchio di Reno, Pitagora offre circa 44 PFlop/s di potenza di calcolo ed è dedicato alla simulazione della fisica del plasma e allo studio dei materiali avanzati per la fusione, integrandosi nell’ecosistema del Tecnopolo di Bologna come infrastruttura strategica finanziata da EUROfusion e gestita in collaborazione con ENEA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Rullo di lavaggio dei pavimenti abbinato a un potente motore da 28.000 Pa e a bracci esterni che si estendono: queste, e molte altre, le caratteristiche tecniche di Z60 Ultra Roller Complete, l'ultimo robot di Mova che pulisce secondo le nostre preferenze oppure lasciando far tutto alla ricca logica di intelligenza artificiale integrata
Renault Twingo E-Tech Electric: che prezzo!
Renault Twingo E-Tech Electric: che prezzo!
Renault annuncia la nuova vettura compatta del segmento A, che strizza l'occhio alla tradizione del modello abbinandovi una motorizzazione completamente elettrica e caratteristiche ideali per i tragitti urbani. Renault Twingo E-Tech Electric punta su abitabilità, per una lunghezza di meno di 3,8 metri, abbinata a un prezzo di lancio senza incentivi di 20.000€
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-05-2006, 15:33   #1
vicus
Member
 
Iscritto dal: Oct 2004
Città: Rossano Veneto
Messaggi: 110
[SQL]Errore in una query con GROUP BY

Il DB è composto da tre tabelle:
Ordine(td,nome,posti,data),Piatti(id,descrizione),Portate(id,descrizione) e da una tabella di appoggio Dettagli(idOrd,idPiatto,idPortata).
La query è la seguente:

SELECT Ordine.nome, SUM(Ordine.posti), Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
WHERE Ordine.data=<input>
GROUP BY portate.descrizione,piatti.descrizione

Ma mi da questo errore:
[Microsoft][ODBC SQL Server Driver][SQL Server]La colonna 'ordini.nome' non è valida nell'elenco di selezione perché non è inclusa né in una funzione di aggregazione né nella clausola GROUP BY.

Come risolvo il mio problema?
__________________
vicus è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:04   #2
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Hai messo una funzione di aggregazione sulla select

Codice:
SELECT Ordine.nome, SUM(Ordine.posti), Piatti.descrizione, Portate.descrizione
quindi nella group by

devi mettere gli altri tre campi, altrimenti ti da errore

Codice:
GROUP BY Ordine.nome, Piatti.descrizione, Portate.descrizione
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:13   #3
vicus
Member
 
Iscritto dal: Oct 2004
Città: Rossano Veneto
Messaggi: 110
Non posso fare così perchè ho bisogno della somma di tutti gli ordini che hanno quel piatto in quella portata.
Questo non è un problema perchè la somma la potrei farla dopo però nemmeno la query
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
WHERE Ordine.data=<input>
GROUP BY portate.descrizione,piatti.descrizione
funziona anche se non c'è la funzione di aggregazione SUM().
__________________
vicus è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:29   #4
vicus
Member
 
Iscritto dal: Oct 2004
Città: Rossano Veneto
Messaggi: 110
Errata corrige:
leggendo una dispensa mi sono ricordato che con il GROUP BY si una HAVING quindi:
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
GROUP BY portate.descrizione,piatti.descrizione 
HAVING Ordine.data=<input>
ma comunque non funziona e l'errore si è esteso alla data perchè non fa parte ne di una funzione di aggregazione ne nella clausola GROUP BY.
__________________
vicus è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:42   #5
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da vicus
Errata corrige:
leggendo una dispensa mi sono ricordato che con il GROUP BY si una HAVING quindi:
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
GROUP BY portate.descrizione,piatti.descrizione 
HAVING Ordine.data=<input>
ma comunque non funziona e l'errore si è esteso alla data perchè non fa parte ne di una funzione di aggregazione ne nella clausola GROUP BY.
Puoi usare where od having a seconda di quello che devi fare
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:45   #6
DvL^Nemo
Senior Member
 
L'Avatar di DvL^Nemo
 
Iscritto dal: Nov 2001
Città: 100 metri dal mare
Messaggi: 4855
Prova cosi'

Quote:
SELECT DISTINCT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
WHERE Ordine.data=<input>
DvL^Nemo è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:47   #7
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da vicus
Non posso fare così perchè ho bisogno della somma di tutti gli ordini che hanno quel piatto in quella portata.
Questo non è un problema perchè la somma la potrei farla dopo però nemmeno la query
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
WHERE Ordine.data=<input>
GROUP BY portate.descrizione,piatti.descrizione
funziona anche se non c'è la funzione di aggregazione SUM().
Se devi fare la somma di tutti gli ordini non puoi mettere anche Ordine.nome nella select, se ho capito bene com'è strutturato il DB...

Ordine.nome cos'è? Nella tabella ordini cosa c'è?
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:48   #8
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da DvL^Nemo
Prova cosi'

Ma così dopo riscia di non poter fare la somma delle protate mi sembra
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:52   #9
DvL^Nemo
Senior Member
 
L'Avatar di DvL^Nemo
 
Iscritto dal: Nov 2001
Città: 100 metri dal mare
Messaggi: 4855
Hai ragione, mi sono limitato a leggere l'ultima query ( dove non c'era traccia del sum ).. cmq ci sarebbe da vedere come e' struturato il DB per capire cosa serve e cosa fare..
Ciao !
DvL^Nemo è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:54   #10
vicus
Member
 
Iscritto dal: Oct 2004
Città: Rossano Veneto
Messaggi: 110
Quote:
Originariamente inviato da Duncan
Se devi fare la somma di tutti gli ordini non puoi mettere anche Ordine.nome nella select, se ho capito bene com'è strutturato il DB...

Ordine.nome cos'è? Nella tabella ordini cosa c'è?
Ordine(id,nome,posti,data)

posso rinunciare alla somma ma questa dovrebbe funzionare
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
GROUP BY portate.descrizione,piatti.descrizione 
HAVING Ordine.data=<input>
ed invece non va.
__________________
vicus è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:54   #11
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da DvL^Nemo
Hai ragione, mi sono limitato a leggere l'ultima query ( dove non c'era traccia del sum ).. cmq ci sarebbe da vedere come e' struturato il DB per capire cosa serve e cosa fare..
Ciao !

A leggere la prima query che ha scritto la soluzione è non mettere Ordine.nome nell'elenco della select, ma bisogna vedere se gli serve o meno quella colonna...
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:56   #12
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da vicus
Ordine(id,nome,posti,data)

posso rinunciare alla somma ma questa dovrebbe funzionare
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
GROUP BY portate.descrizione,piatti.descrizione 
HAVING Ordine.data=<input>
ed invece non va.

C'è un errore di fondo, così non ti funzionerà mai, le colonne che specifichi nella clausola select le devi mettere anche nella group by a meno che non sia usate, nella select stessa, in funzioni di aggregazione ([i]SUM, COUNT, AVG ecc)
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:57   #13
DvL^Nemo
Senior Member
 
L'Avatar di DvL^Nemo
 
Iscritto dal: Nov 2001
Città: 100 metri dal mare
Messaggi: 4855
Quote:
Originariamente inviato da vicus
Ordine(id,nome,posti,data)

posso rinunciare alla somma ma questa dovrebbe funzionare
Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
GROUP BY portate.descrizione,piatti.descrizione 
HAVING Ordine.data=<input>
ed invece non va.
E allora se non ti serve la somma prova questa che funziona

Quote:
SELECT DISTINCT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
WHERE Ordine.data=<input>
DvL^Nemo è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 16:59   #14
vicus
Member
 
Iscritto dal: Oct 2004
Città: Rossano Veneto
Messaggi: 110
Non posso usare usare funzioni di aggregazione, togliere il nome o includerlo nel group by.
Mi dovro inventare qualcosa costituito da più query.
__________________
vicus è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 17:01   #15
DvL^Nemo
Senior Member
 
L'Avatar di DvL^Nemo
 
Iscritto dal: Nov 2001
Città: 100 metri dal mare
Messaggi: 4855
Esegui la query che ti ho scritto e vediamo se funziona
Tanto hai detto il SUM lo recuperi da altre parti..
Ciao !
DvL^Nemo è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 17:02   #16
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da DvL^Nemo
E allora se non ti serve la somma prova questa che funziona


Si con la distinct funziona, ed anche con la group by, solo che dopo non è possible usare ordine.posti per sommare, perchè i valori duplicati sono stati eliminati dalla distinct o raggruppati dalla group by


IMHO la query giusta è

Codice:
SELECT SUM(Ordine.posti), Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
WHERE Ordine.data=<input>
GROUP BY portate.descrizione,piatti.descrizione
A che ti serve Ordine.nome? Cosa c'è scritto dentro?
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 17:04   #17
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Scusa ma nella tabella ordine cosa c'è dentro?

Codice:
Tabella Ordine

id = chiave tabella?
nome = ???
posti = numero di portate ordinate?
data = data ordine

Spiegami un po', perchè altrimenti mi riesce difficile cosa c'è dentro
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 17:06   #18
DvL^Nemo
Senior Member
 
L'Avatar di DvL^Nemo
 
Iscritto dal: Nov 2001
Città: 100 metri dal mare
Messaggi: 4855
In effetti quell'ordine.nome e' strano, la mia "preoccupazione" e' che sia strutturato male il DB, perche' se il group by va utilizzato in una certe maniera c'e' un motivo..
Ciao !
DvL^Nemo è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 17:09   #19
Duncan
Senior Member
 
L'Avatar di Duncan
 
Iscritto dal: Nov 1999
Città: Sesto Fiorentino, Firenze
Messaggi: 8444
Quote:
Originariamente inviato da DvL^Nemo
In effetti quell'ordine.nome e' strano, la mia "preoccupazione" e' che sia strutturato male il DB, perche' se il group by va utilizzato in una certe maniera c'e' un motivo..
Ciao !

Infatti è anche la mia paura, se devi sommare Ordine.posti, se il DB è corretto i casi sono due
  1. Non di interessa nulla di Ordine.Nome
  2. O lo metti in Group by e select
__________________
Nikon user
Le mie foto su Flickr
Duncan è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2006, 17:17   #20
vicus
Member
 
Iscritto dal: Oct 2004
Città: Rossano Veneto
Messaggi: 110
Allora
tabella ordini:
nome: chi ha fatto l'ordine
posti: per quante persone
data: per quando ha prenotato

A me serve sapere per quante persone e in quali ordini serve un piatto di un dato giorno.

Codice:
SELECT Ordine.nome, Ordine.posti, Piatti.descrizione, Portate.descrizione
FROM 'le quattro tabelle unite col INNER JOIN sul codice'
GROUP BY portate.descrizione,piatti.descrizione 
HAVING Ordine.data=<input>
Questa in Access funziona.

Sono uno studente e questo è il primo DB serio che faccio quindi è possibile che sia fatto male daltronde lo rifatto solo 2 volte.
__________________
vicus è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare Cineca inaugura Pitagora, il supercomputer Lenov...
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA Mova Z60 Ultra Roller Complete: pulisce bene gra...
Renault Twingo E-Tech Electric: che prezzo! Renault Twingo E-Tech Electric: che prezzo!
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
'Senza TSMC non ci sarebbe NVIDIA': Jens...
Fumo di sigaretta e sporco per 17 anni: ...
Resi Amazon Natale 2025: cambiano i temp...
L'SSD modulare aggiornabile come un PC: ...
Intel ha denunciato un ex dipendente per...
Blue Origin rinvia il secondo lancio del...
Nasce l'albo degli influencer 'rilevanti...
Il Digital Networks Act è stato r...
ASUS ROG ha lanciato due nuovi monitor d...
I nuovi iPhone 18 Pro potrebbero present...
Una parte dei Galaxy S26 avrà chi...
Amazon permetterà agli autori ind...
Il caso Zuckerberg a Palo Alto: una scuo...
Texas contro Roblox: il procuratore gene...
Offerte auto da urlo su Amazon: da CarPl...
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: 07:41.


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