Torna indietro   Hardware Upgrade Forum > Software > Programmi e Utility

DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone
Ad Appian Europe 2025, l'azienda parla molto della sua visione di cos'è e come dovrebbe essere usata l'intelligenza artificiale: è uno strumento che va sempre adoperato dalle persone, che devono rimanere responsabili dei processi all'interno dell'azienda. Non è un giocattolo con cui sperimentare, ma un aiuto per superare le sfide di business più importanti
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-07-2009, 21:40   #1
dark.shark.dsk
Senior Member
 
Iscritto dal: Sep 2004
Messaggi: 324
Openoffice Base - Come calcolare una media in una query

Ciao a tutti,
ho qualche problemino nel far calcolare ad una query una media di 3 campi...

Al momento ho provato ad inserire questa forumula in un campo vuoto della query:
("campo1" + "campo2" + "campo3")/3

La cosa funziona bene però solo se tutti e tre i campi sono popolati, mentre se uno è vuoto, anche il campo della media rimane vuoto, mentre a me servirebbe che nel caso ci fossero solo 2 numeri o anche uno solo la media me la calcoli lo stesso...

Mi piacerebbe anche sapere se oltre alla mendia c'è magari una formula già fatta per calcolare la deviazione standard...

Grassie dell'aiuto!
__________________
Non è morto ciò che in eterno può attendere,
E con il passare di strane ere anche la morte muore.
dark.shark.dsk è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 14:56   #2
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Ciao. Non utilizzo Base ma nel caso adotti un sql standard prova a fare

select coalesce(campo1,0) + coalesce(campo2,0) + coalesce(campo3,0) as totale from tabella.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 16:00   #3
Raffaele53
Senior Member
 
Iscritto dal: Feb 2008
Messaggi: 1514
Se la cella riporta uno zero, la funzione Media viene calcolata diviso 4.
2 4 8 0
=MEDIA(C9;D9;E9;F9) risultato 3,5

Se la cella risulta vuota, la funzione Media viene calcolata diviso 3
2 4 8 (vuota)
=MEDIA(C9;D9;E9;F9) risultato 4,67

Casomai =se(esito x cella=0;"";esito x cella)
OpenOffice 3,10

Ultima modifica di Raffaele53 : 09-07-2009 alle 16:03.
Raffaele53 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 18:27   #4
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Ho dato uno sguardo a Base e devo dire che la sua gestione dell'sql fa abbastanza schifo.

Comunque la tua query definitiva dovrebbe essere questa:

Codice:
SELECT "campo1", "campo2", "campo3", ( coalesce( "campo1", 0 ) + coalesce( "campo2", 0 ) + coalesce( "campo3", 0 ) ) / ( casewhen( "campo1" <> 0, 1, 0 ) + casewhen( "campo2" <> 0, 1, 0 ) + casewhen( "campo3" <> 0, 1, 0 ) ) AS "media" FROM "tabella"
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 19:40   #5
emmedi
Senior Member
 
Iscritto dal: Dec 2000
Città: Pozzomaggiore (SS)
Messaggi: 12583
Base usa di default questo motore http://hsqldb.org.
Magari nella documentazione del sito trovi la sintassi.

Ricordo che per le discussioni su Openoffice.org esiste la discussione ufficiale:
http://www.hwupgrade.it/forum/showthread.php?t=1044718
emmedi è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 23:06   #6
dark.shark.dsk
Senior Member
 
Iscritto dal: Sep 2004
Messaggi: 324
Grazie a tutti per i consigli!
Ora mi metto a vedere cosa riesco a combinare....

@ john_revelator
Tanto per sapere, esattamente la funzione "coalesce" così che fa?
__________________
Non è morto ciò che in eterno può attendere,
E con il passare di strane ere anche la morte muore.
dark.shark.dsk è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 23:21   #7
dark.shark.dsk
Senior Member
 
Iscritto dal: Sep 2004
Messaggi: 324
@ john_revelator

Funziona! Sei un genio! Grazie mille!!!

A questo punto mi faresti davvero un piacere se mi potessi spiegare esattamente come funge la formula che hai usato, così capisco come applicarla anche ad altri calcoli matematici!
__________________
Non è morto ciò che in eterno può attendere,
E con il passare di strane ere anche la morte muore.
dark.shark.dsk è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2009, 00:13   #8
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Come hai avuto modo di notare tu stesso, andando a sommare i vari campi, nel caso anche uno solo sia pari a null, la somma risulta ugualmente pari a null.

La funzione coalesce (com'era facilmente reperibile con una ricerchina su google ) restituisce la prima espressione non null tra i relativi argomenti. Quindi impostando il secondo parametro a 0, nel caso il primo (il nome del campo) non sia null, verrà restituito il suo valore, in caso contrario verrà restituito 0 anzichè null e quindi la somma andrà a buon fine. Ho perso dieci minuti buoni a imprecare prima di rendermi conto che in Base non esiste la funzione if ma bensì casewhen.
Per poter fare la media devo sapere per quanto devo dividere (1,2 o 3) e quindi con la seconda parte della query verifico uno ad uno i valori.
Altra cosa che mi ha fatto inca**are di Base è che non c'è stato verso di testare se il campo fosse "is null" ma ha richiesto il confronto con lo 0, mah.
Quindi ho verificato ciascuno dei tre campi per vedere se fosse compilato o meno (facendomi restituire 1 o 0) e la somma di tale confronto dei tre campi restituisce il valore per cui devo dividere.

Spero di essere stato chiaro.

edit. Per quel che riguarda la tua richiesta relativa alla deviazione standard, oltre al link che ti ha dato il mio vicino dai uno sguardo anche qui

http://wiki.services.openoffice.org/...red_Procedures

Ultima modifica di john_revelator : 10-07-2009 alle 00:30.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2009, 00:45   #9
dark.shark.dsk
Senior Member
 
Iscritto dal: Sep 2004
Messaggi: 324
Ho capito, grazie per la spiegazione.

Cmq lo so che c'è google, ma alle volte, quando è possibile, è trovo che sia ancora meglio chiedere direttamente spiegazioni all'autore, sopratutto per fare magari quattro chiacchere con qualcuno che evidentemente ne sa più di me...
__________________
Non è morto ciò che in eterno può attendere,
E con il passare di strane ere anche la morte muore.
dark.shark.dsk è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2009, 14:00   #10
Raffaele53
Senior Member
 
Iscritto dal: Feb 2008
Messaggi: 1514
Pardon, meglio tardi che mai............Base significa Access

Il bello che ho anche visto quando hai scritto Query, ma non ci ho fatto caso perchè in quel momento avevo un problema con Calc (Excel)
Raffaele53 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
Presentato il nuovo obiettivo Laowa 35mm...
ESA ha proposto un aumento del budget da...
Piratare Battlefield 6? Davvero una pess...
Arriva Veeam Data Platform v13. Pi&ugrav...
Framework interrompe la vendita di RAM: ...
Tachyum inventa le memorie TDIMM: una nu...
Roborock Q7 TF+, il robot economico cost...
Osca rinasce: le auto dei fratelli Maser...
Hlpy, la tecnologia al servizio dell’ass...
Ericsson rilancia sul 5G Standalone: l’I...
Black Friday Amazon: arrivano i super-sc...
Seagate raggiunge 6,9 TB per piatto con ...
Samsung lancia la One Shot Challenge: co...
Dell: il passaggio da Windows 10 a Windo...
Black Friday Speaker: JBL, Bose, Sony, M...
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: 23:06.


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