Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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€
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media
Nel Formula 1 Technology and Media Centre di Biggin Hill, la velocità delle monoposto si trasforma in dati, immagini e decisioni in tempo reale grazie all’infrastruttura Lenovo che gestisce centinaia di terabyte ogni weekend di gara e collega 820 milioni di spettatori nel mondo
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
Il nuovo gimbal mobile DJI evolve il concetto di tracciamento automatico con tre modalità diverse, un modulo multifunzionale con illuminazione integrata e controlli gestuali avanzati. Nel gimbal è anche presente un'asta telescopica da 215 mm con treppiede integrato, per un prodotto completo per content creator di ogni livello
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-02-2011, 12:05   #1
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
[sql] porre a zero un campo in una select

Vi scrivo perchè ho un dubbio, ci sono alcune query che sto facendo in cui dice tipo "sommare la quantità di articoli per ciascun ordine e dove non ce ne sono porre a 0 la qunatità ordinata".

Il problema è quel "porre a 0", io con prove a casaccio su mysql mi sono accorto che se fai una select del tipo:

Select codice, 0 from articoli;

Praticamente associa ad ogni codice il valore zero.

Il dubbio mio è che magari non è sql standard ed al professore non vada bene (essendo un esame di sql, ed uso mysql giusto per verificare gli esercizi che svolgo).

Secondo voi la mia solzione è sql standard? altrimenti come si potrebbe fare?

Vi ringrazio in anticipo,
guylmaster.
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 14-02-2011, 12:25   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Semplicemente se fai la somma dei valori se non ve ne sono ottieni 0.
Eventualmente per campi nullabili le soluzioni sono diverse, una di queste è:
Codice:
SELECT SUM(COALESCE(colonna,0)) as Somma FROM Tabella WHERE ...
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 14-02-2011, 22:16   #3
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Semplicemente se fai la somma dei valori se non ve ne sono ottieni 0.
Eventualmente per campi nullabili le soluzioni sono diverse, una di queste è:
Codice:
SELECT SUM(COALESCE(colonna,0)) as Somma FROM Tabella WHERE ...
COALESCE dovrebbe essere una paroal chiave? che sarebbe ?

Sostanzialemnte il caso problematico è il join tra più tabelle.
Quindi ho tipo una tabella di articoli ed una tabella di ordini, e devo ad esempio dire quanti articoli sono stati venduti facendo il join tra le due tabelle.

Ora gli articoli che non si presentano in nessun ordine non appaiono, allora faccio una union e cerco prorpio quelle colonne che non appaiono per settarle a zero.

Quella funzione "coalesce" temo che sia un'altra funzione propria del mysql, ed il problema è che mi serve per un esame che è di sql, quindi mi servirebbe una soluzione in sql "puro". Perchè senno in mysql la mia soluzione è già un "select codice, 0 where..". Il problema è che la mia soluzione non so se è una cosa possibile solo in mysql o va bene anche in sql puro.
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 14-02-2011, 23:28   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
[quote=guylmaster;34456066]COALESCE dovrebbe essere una paroal chiave? che sarebbe ?
[quote]

Google avrebbe potuto darti una risposta immediata.
Coalesce restituisce il valore della colonna, oppure il valore specificato nel caso in cui il campo sia NULL.

Quote:
Sostanzialemnte il caso problematico è il join tra più tabelle.
Quindi ho tipo una tabella di articoli ed una tabella di ordini, e devo ad esempio dire quanti articoli sono stati venduti facendo il join tra le due tabelle.

Ora gli articoli che non si presentano in nessun ordine non appaiono, allora faccio una union e cerco prorpio quelle colonne che non appaiono per settarle a zero.
Ma usare un group by sull'id articolo?

Quote:
Quella funzione "coalesce" temo che sia un'altra funzione propria del mysql, ed il problema è che mi serve per un esame che è di sql, quindi mi servirebbe una soluzione in sql "puro".
Coalesce fa parte di Sql92, pertanto nessun problema.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 21:31   #5
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
[quote=tomminno;34456525][quote=guylmaster;34456066]COALESCE dovrebbe essere una paroal chiave? che sarebbe ?
Quote:

Google avrebbe potuto darti una risposta immediata.
Coalesce restituisce il valore della colonna, oppure il valore specificato nel caso in cui il campo sia NULL.



Ma usare un group by sull'id articolo?



Coalesce fa parte di Sql92, pertanto nessun problema.
Perfetto, se utilizzo coalesce(0) equivale a dire di impostare un intera colonna a zero indistintamente?
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 22:05   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da guylmaster Guarda i messaggi
Perfetto, se utilizzo coalesce(0) equivale a dire di impostare un intera colonna a zero indistintamente?
No Coalese(0) è sbagliato in quanto accetta 2 parametri.
Se devi selezionare una colonna fissa a 0, ma non mi sembrava il tuo caso, allora esegui una select specificando 0 tra i campi da selezionare.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 22:10   #7
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
Quote:
Originariamente inviato da tomminno Guarda i messaggi
No Coalese(0) è sbagliato in quanto accetta 2 parametri.
Se devi selezionare una colonna fissa a 0, ma non mi sembrava il tuo caso, allora esegui una select specificando 0 tra i campi da selezionare.
No, mi era capitata in un'altro caso. Il punto è che non so se quel select 0 sia accettabile in sql standard o meno.
guylmaster è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce Recensione Pura 80 Pro: HUAWEI torna a stupire c...
Opera Neon: il browser AI agentico di nuova generazione Opera Neon: il browser AI agentico di nuova gene...
DJI Osmo 360 ai prezzi più bassi ...
Il nuovo Edge 70 conferma la strategia v...
Il Re dei mini PC economici: 160€ con 16...
Smartphone, tablet e auricolari a soli 2...
Square Enix guarda al futuro: più...
Crolla a 89€ una scopa elettrica low cos...
Anche Huawei segue il trend del mercato:...
Un portatile un tuttofare definitivo a 5...
PosteMobile passerà alla rete TIM...
I 6 migliori smartphone da acquistare su...
iPhone Air 2 è già in cant...
OnePlus 15, in Europa sarà uguale...
Portal X, un nuovo modo per controllare ...
Con Satispay ora si può pagare in...
Sora sbarca anche su Android: una nuova ...
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: 09:43.


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