PDA

View Full Version : [sql] porre a zero un campo in una select


guylmaster
14-02-2011, 12:05
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.

tomminno
14-02-2011, 12:25
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 è:

SELECT SUM(COALESCE(colonna,0)) as Somma FROM Tabella WHERE ...

guylmaster
14-02-2011, 22:16
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 è:

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.

tomminno
14-02-2011, 23:28
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?


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.

guylmaster
16-02-2011, 21:31
[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?

tomminno
16-02-2011, 22:05
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.

guylmaster
16-02-2011, 22:10
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.