Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
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: 4856
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: 4856
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: 4856
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: 4856
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: 4856
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


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Starfield per Nintendo Switch 2 potrebbe...
Un MacBook Pro a -300€, i MacBook Air M4...
Amazon abbassa i prezzi sugli iPhone: sc...
Amazon, ancora sconti sugli smartphone A...
iPhone Air 2 'riciclerà' alcuni c...
Offerta Amazon da non perdere: lo speake...
Nioh 3 debutta alla grande su Steam: pri...
Al centro della Via Lattea ci potrebbe e...
Elon Musk ora guarda alla Luna: SpaceX p...
La Cina ha lanciato nuovamente lo spazio...
Blue Origin potrebbe realizzare il lande...
Artemis II: il prossimo Wet Dress Rehear...
Il nuovo HONOR 600 sta arrivando e avr&a...
La crisi delle memorie non coinvolger&ag...
Windows domina su Steam, ma molti utenti...
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: 10:28.


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