Torna indietro   Hardware Upgrade Forum > Software > Programmazione

MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-04-2010, 11:05   #1
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
[MySQL] Come posso effettuare questo semplice calcolo con una query?

Salve a tutti,

supponiamo di avere una tabella 'ACQUISTI' come la seguente:
Codice:
+-------------+----------+----------------+
| MATERIALE   | QUANTITA | COSTO_UNITARIO |
+-------------+----------+----------------+
| materiale_1 |       25 |           1.00 |
| materiale_2 |        5 |          15.00 |
| materiale_3 |        7 |          32.00 |
| materiale_4 |        7 |          55.00 |
| materiale_5 |        4 |           2.00 |
| materiale_6 |       10 |           3.00 |
| materiale_7 |       10 |           4.00 |
+-------------+----------+----------------+
È possibile, facendo una query SQL, sapere il costo totale degli acquisti?
Ovvero, fare 25*1+5*15+....+10*4=787.
So che si possono fare delle operazioni ma non sono molto ferrato

Qualcuno lo sa?
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 11:36   #2
british
Member
 
L'Avatar di british
 
Iscritto dal: Sep 2008
Città: Milano
Messaggi: 126
Quote:
Originariamente inviato da fbcyborg Guarda i messaggi
È possibile, facendo una query SQL, sapere il costo totale degli acquisti?
si.
imposta una SELECT in cui una delle colonne è creata dall'operatore
Codice:
SUM(<colonna di cui sommare le righe>)
.
Questo operatore restituisce la sommatoria di tutte le righe di <colonna di cui sommare le righe>.
<colonna di cui sommare le righe> può essere una singola colonna oppure un insieme di colonne con in mezzo operatori aritmetici (nel tuo caso "*" )...

guarda anche
http://www.w3schools.com/sql/sql_func_sum.asp
per l'uso "base" di SUM()

ciao!

british
british è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 11:52   #3
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Grazie! Non sapevo potessi fare
Codice:
SUM(QUANTITA*COSTO_UNITARIO) AS SOMMA
Effettivamente funziona alla grande!

Grazie ancora!
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 11:53   #4
lupoxxx87
Senior Member
 
Iscritto dal: Jul 2009
Città: Varès
Messaggi: 658
il modo più semplice è quello di avere una quarta colonna SUBTOT, calcolata da una stored procedure,
e poi con una select fai la somma dei valori di quella colonna

select sum(subtot) from acquisti

edit:

dovrebbe essere anche accettata direttamente la query

select sum(quantità * costo_unitario) from acquisti

Ultima modifica di lupoxxx87 : 20-04-2010 alle 12:35.
lupoxxx87 è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 12:36   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ehm, non mi sembra tanto semplice...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 19:13   #6
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Quote:
Originariamente inviato da lupoxxx87 Guarda i messaggi
dovrebbe essere anche accettata direttamente la query

select sum(quantità * costo_unitario) from acquisti
Eh ma infatti! È il metodo che ho adottato!
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 19:54   #7
lupoxxx87
Senior Member
 
Iscritto dal: Jul 2009
Città: Varès
Messaggi: 658
ti funziona ?
lupoxxx87 è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 20:36   #8
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Sembrerebbe proprio di sì!!!
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 20:41   #9
zuper
Senior Member
 
Iscritto dal: Mar 2001
Città: PV Milano Nord
Messaggi: 3851
puoi anche fare le singole * e poi fare il totale

select MATERIALE, QUANTITA*COSTO_UNITARIO as 'COSTO' from ACQUISTI
union
select 'TOTALE', SUM(QUANTITA*COSTO_UNITARIO) from ACQUISTI
__________________
"W la foca, che dio la benedoca"
poteva risolvere tutto la sinistra negli anni in cui ha governato e non l'ha fatto. O sono incapaci o sta bene anche a "loro" cosi.
L'una o l'altra inutile scandalizzarsi.[plutus]
zuper è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 22:06   #10
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Grazie, sembra comunque che le cose funzionino abbastanza bene.
In realtà ciò che ho chiesto inizialmente mi serviva di aiuto per risolvere un altro problema, ma sono rimasto "fregato" per il momento.

La situazione è questa:
Ho n magazzini e sono tutti memorizzati nella tabella magazzini:
Codice:
MAGAZZINI
+-------------+-------+
| NOME_MAG    | SEDE  |
+-------------+-------+
| magazzino_1 | sede1 |
| magazzino_2 | sede2 |
| magazzino_3 | sede3 |
| magazzino_4 | sede4 |
| magazzino_5 | sede5 |
| magazzino_6 | sede6 |
| magazzino_7 | sede7 |
+-------------+-------+
L'applicazione prevede che vengano acquistati dei materiali e che se ne memorizzi il costo in un'altra tabella, e che si memorizzi il magazzino in cui andrà a finire ogni materiale:
Codice:
MATERIALI_ASSEGNATI_AI_MAGAZZINI
+-------------+-------------+----------+----------------+
| NOME_MAG    | MATERIALE   | QUANTITA | COSTO_UNITARIO |
+-------------+-------------+----------+----------------+
| magazzino_1 | materiale_1 |       25 |           1.00 |
| magazzino_1 | materiale_2 |        5 |          15.00 |
| magazzino_1 | materiale_3 |        7 |          32.00 |
| magazzino_2 | materiale_4 |        7 |          55.00 |
| magazzino_3 | materiale_5 |        4 |           2.00 |
| magazzino_6 | materiale_6 |       10 |           3.00 |
| magazzino_6 | materiale_7 |       10 |           4.00 |
+-------------+-------------+----------+----------------+
Ora la domanda è: a quanto ammonta il costo di ogni singolo magazzino?
In questo caso, vorrei una query che mi restituisse questo risultato:
Codice:
COSTO MAGAZZINI
+-------------+-------+----------------+
| NOME_MAG    | SEDE  | COSTO_TOTALE   |
+-------------+-------+----------------+
| magazzino_1 | sede1 |         324.00 |
| magazzino_2 | sede2 |         385.00 |
| magazzino_3 | sede3 |           8.00 |
| magazzino_4 | sede4 |           0.00 |
| magazzino_5 | sede5 |           0.00 |
| magazzino_6 | sede6 |          70.00 |
| magazzino_7 | sede7 |           0.00 |
+-------------+-------+----------------+
Con le soluzioni che mi avete proposto fin'ora so calcolarmi il costo di un magazzino, ma essendo n magazzini, vorrei far calcolare quella funzione per ognuno, cosa che non riesco a fare, a meno di qualche raggiro a livello di programmazione. Ma prima volevo sentire voi, prima di scrivere software assurdo per calcolare qualcosa che magari è fattibile a livello di SQL!

Grazie!
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 22:08   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Devi usare GROUP BY. Però queste cose le trovi su qualsiasi manuale base di sql
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 23:37   #12
zuper
Senior Member
 
Iscritto dal: Mar 2001
Città: PV Milano Nord
Messaggi: 3851
Quote:
Originariamente inviato da fbcyborg Guarda i messaggi
Grazie, sembra comunque che le cose funzionino abbastanza bene.
In realtà ciò che ho chiesto inizialmente mi serviva di aiuto per risolvere un altro problema, ma sono rimasto "fregato" per il momento.

La situazione è questa:
Ho n magazzini e sono tutti memorizzati nella tabella magazzini:
Codice:
MAGAZZINI
+-------------+-------+
| NOME_MAG    | SEDE  |
+-------------+-------+
| magazzino_1 | sede1 |
| magazzino_2 | sede2 |
| magazzino_3 | sede3 |
| magazzino_4 | sede4 |
| magazzino_5 | sede5 |
| magazzino_6 | sede6 |
| magazzino_7 | sede7 |
+-------------+-------+
L'applicazione prevede che vengano acquistati dei materiali e che se ne memorizzi il costo in un'altra tabella, e che si memorizzi il magazzino in cui andrà a finire ogni materiale:
Codice:
MATERIALI_ASSEGNATI_AI_MAGAZZINI
+-------------+-------------+----------+----------------+
| NOME_MAG    | MATERIALE   | QUANTITA | COSTO_UNITARIO |
+-------------+-------------+----------+----------------+
| magazzino_1 | materiale_1 |       25 |           1.00 |
| magazzino_1 | materiale_2 |        5 |          15.00 |
| magazzino_1 | materiale_3 |        7 |          32.00 |
| magazzino_2 | materiale_4 |        7 |          55.00 |
| magazzino_3 | materiale_5 |        4 |           2.00 |
| magazzino_6 | materiale_6 |       10 |           3.00 |
| magazzino_6 | materiale_7 |       10 |           4.00 |
+-------------+-------------+----------+----------------+
Ora la domanda è: a quanto ammonta il costo di ogni singolo magazzino?
In questo caso, vorrei una query che mi restituisse questo risultato:
Codice:
COSTO MAGAZZINI
+-------------+-------+----------------+
| NOME_MAG    | SEDE  | COSTO_TOTALE   |
+-------------+-------+----------------+
| magazzino_1 | sede1 |         324.00 |
| magazzino_2 | sede2 |         385.00 |
| magazzino_3 | sede3 |           8.00 |
| magazzino_4 | sede4 |           0.00 |
| magazzino_5 | sede5 |           0.00 |
| magazzino_6 | sede6 |          70.00 |
| magazzino_7 | sede7 |           0.00 |
+-------------+-------+----------------+
Con le soluzioni che mi avete proposto fin'ora so calcolarmi il costo di un magazzino, ma essendo n magazzini, vorrei far calcolare quella funzione per ognuno, cosa che non riesco a fare, a meno di qualche raggiro a livello di programmazione. Ma prima volevo sentire voi, prima di scrivere software assurdo per calcolare qualcosa che magari è fattibile a livello di SQL!

Grazie!
qualcosa tipo

select sede.nome_mag, sede.sede, sum(acquisti.quantita*acquisti.costo_unitario)
from sede, acquisti
where sede.nome_mag=acquisti.nome_mag
group by sede.sede, sede.nome_mag
__________________
"W la foca, che dio la benedoca"
poteva risolvere tutto la sinistra negli anni in cui ha governato e non l'ha fatto. O sono incapaci o sta bene anche a "loro" cosi.
L'una o l'altra inutile scandalizzarsi.[plutus]
zuper è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2010, 11:01   #13
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Grazie!

Funziona tutto correttamente!
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Kodak Charmera Millennium Edition: torna...
Il catalogo di XBOX Game Pass sempre pi&...
Il futuro della medicina? Midjourney vuo...
Ricercatori di Harvard codificano 169 by...
AOC E4: monitor ergonomici per PMI con r...
Apple guarda al futuro: il primo chip a ...
L'addio al PC un autogol per PlayStation...
DJI Mini 4K parte da 179€, DJI Neo da 13...
WINDTRE alza ancora i prezzi: sesta rimo...
iPhone 18 potrebbe avere più RAM ...
The Witcher, in arrivo anche un gioco mu...
Un miliardo di utenti non basta: ChatGPT...
Carl Pei di Nothing sfida Apple: 'Vi rub...
Morale a terra in casa Meta: persino i d...
SK hynix consegna le memorie HBM4E da 48...
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: 08:07.


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