Torna indietro   Hardware Upgrade Forum > Software > Programmi e Utility

Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Abbiamo provato per diversi giorni una new entry del mercato italiano, la Gowow Ori, una moto elettrica da off-road, omologata anche per la strada, che sfrutta una pendrive USB per cambiare radicalmente le sue prestazioni
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
OnePlus 15 nasce per alzare l'asticella delle prestazioni e del gaming mobile. Ma non solo, visto che integra un display LTPO 1,5K a 165 Hz, OxygenOS 16 con funzioni AI integrate e un comparto foto con tre moduli da 50 MP al posteriore. La batteria da 7.300 mAh con SUPERVOOC 120 W e AIRVOOC 50 W è la ciliegina sulla torta per uno smartphone che promette di offrire un'esperienza d'uso senza alcun compromesso
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
Vediamo come si comporta il Ryzen 5 7500X3D, nuovo processore di casa AMD che fonde 6 core Zen 4 con la tecnologia 3D V-Cache, particolarmente utile in scenari come il gaming. Annunciato a un prezzo di listino di 279€, il nuovo arrivato sarà in grado di diventare un riferimento per i sistemi budget? Ecco cosa ne pensiamo.
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


Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media AMD Ryzen 5 7500X3D: la nuova CPU da gaming con ...
SONY BRAVIA 8 II e BRAVIA Theatre System 6: il cinema a casa in formato compatto SONY BRAVIA 8 II e BRAVIA Theatre System 6: il c...
KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo KTC H27E6 a 300Hz e 1ms: come i rivali ma a met&...
Anche Firefox punta sull'intelligenza ar...
Stop alle super-accelerazioni delle auto...
Osservatorio AGCOM: sempre più ac...
Sempre più IA su Spotify: arrivan...
iMac M4 crolla a 1.199€ con risparmio di...
Nintendo Switch 2: in rilascio un nuovo ...
Core Ultra 9 290K Plus, Core Ultra 7 270...
Prezzo Black Friday per le super cuffie ...
Crollano i prezzi della cuffie Beats col...
ASUS ROG Matrix RTX 5090 costa 4000 doll...
Grazie ai dati di ESA il calcolo della t...
Rilasciati nuovi video e immagini della ...
Gli astronauti cinesi di Shenzhou-20 son...
Mai così tanti gas serra: il 2025...
Google condannata in Germania: favorito ...
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: 14:35.


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