Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-02-2011, 11: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, 11: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, 21: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, 22: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, 20: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, 21: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, 21: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


Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
007 First Light ha venduto più di...
Harley-Davidson, svelato il prezzo itali...
PC Windows 11 in crash: ma la colpa è di...
Dopo i 'NO 5G' arrivano i 'NO FIBRA'? Ar...
Promettono un parco e costruiscono un da...
L'aeroplano supersonico ''silenzioso'' N...
Euro-Office sbugiardata da LibreOffice: ...
I 10 sconti TOP Amazon: 4 novità ...
Galaxy Z Flip 8, in Europa avrà i...
SpaceX annuncia i satelliti AI1 destinat...
Ariston DEOS 10 EVO a 103€: deumidificat...
Cina pronta a investire 295 miliardi di ...
Gli israeliani di NSO Group continuano a...
AMD scommette 2 miliardi di sterline sul...
WhatsApp annuncia la fine del supporto p...
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: 16:40.


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