Cacolo con query

  • Creatore Discussione Creatore Discussione nofcfro
  • Data di inizio Data di inizio

nofcfro

Utente Attivo
27 Mag 2012
72
0
6
Salve,
devo fare un calcolo: prima devo sommare alcuni risultati e poi dividerli per 2, come posso fare?

PHP:
$query = "SELECT SUM(***) as cnt e tutto il resto"; //mi fa la somma dei valori
//qui dovrei passare il risultato della query e dividerlo per due
            $db->setQuery($nuovaquerycondivisione);
            $rows = $db->loadObjectList();

Grazie in anticipo
 
Funziona se divido per una costante :)
ma se dovessi dividere per il risultato di una query precedente, come posso fare?
es. SELECT SUM(***)/$altraquery as cnt ....
 
Funziona se divido per una costante :)
ma se dovessi dividere per il risultato di una query precedente, come posso fare?
es. SELECT SUM(***)/$altraquery as cnt ....
va bene come hai scritto tu, di fatto "$altraquery" è come se fosse una costante, nella posizione in cui si trova,

ma se non ti serve il risultato intermedio che parcheggi in "$altraquery", per altre elaborazioni, puoi unire le due query, esempio
SELECT SUM(***) / ( SELECT count(*) .... ) as cnt
l'importante è che la query "divisore" restituisca un solo valore

ciao
Marino
 
Ultima modifica:
E' un codice scritto da terzi che sto cercando di modificare :)
C'è qualcosa che non capisco perché anche se scrivo:

PHP:
	$a= 2;
	$b= 6;
	$query = $a+ $b;
	$db->setQuery($query);
        $rows = $db->loadObjectList();

mi dà errore...
Siccome si tratta di un'espressione che richiede più variabili (sotto forma di query) sarebbe ottimo avere questa struttura
PHP:
$a = query 1
$b = query 2
$c = query 3
$risultato = $a + $b + $c;

Come posso scrivere questa operazione tra query? :(
 
le select che si usano per le operazioni devono restituire uno e un solo valore, fatta questa premessa, l'esempio,

PHP:
$query = "
( select count(*) from tabella1 where condizione ) + ( select count(*) from tabella2 where condizione ) + ....
";
ciscuna select dell'esempio restituisce un valore che può essere sommato

in fondo a tutte le select puoi inserire anche un alias " as nome" se vuoi assegnare un nome al valore risultante
(a scanso di equivoci metti tutte le select tra parentesi e poi metti alias)

( (select ....) + (select ....) + ... ) as nome

se hai difficoltà posta la query ed il relativo errore

è necessario anche capire cosa contiene la funzione "loadObjectList"
 
Ultima modifica:
Esatto, nelle mille prove tra tutte le combinazioni possibili ho fatto anche:

PHP:
$query = "(SELECT SUM(me.count) as cnt,CONCAT(pl.first_name,' ',pl.last_name) as name, t.t_name,t.id as tid ,ev.e_img,ev.e_name,pl.id,pl.def_img FROM #__bl_match_events as me, #__bl_match as m, #__bl_matchday as md, #__bl_players as pl, #__bl_events as ev ,#__bl_teams as t  WHERE  t.id=pl.team_id AND ev.id=me.e_id AND me.e_id = ".$event_id." AND me.match_id = m.id AND m.m_played = 1 AND md.id=m.m_id AND md.s_id=".$s_id." AND me.player_id = pl.id  ".($team_id?' AND t.id='.$team_id:'')." GROUP BY me.player_id ORDER BY cnt desc LIMIT 15) 
/ 
(SELECT SUM(m.m_played) as cnt,CONCAT(pl.first_name,' ',pl.last_name) as name, t.t_name,t.id as tid ,ev.e_img,ev.e_name,pl.id,pl.def_img FROM #__bl_match_events as me, #__bl_match as m, #__bl_matchday as md, #__bl_players as pl, #__bl_events as ev ,#__bl_teams as t  WHERE  t.id=pl.team_id AND ev.id=me.e_id AND me.e_id = ".$event_id." AND me.match_id = m.id AND m.m_played = 1 AND md.id=m.m_id AND md.s_id=".$s_id." AND me.player_id = pl.id  ".($team_id?' AND t.id='.$team_id:'')." GROUP BY me.player_id ORDER BY cnt desc LIMIT 15)";

Si tratta di un'estensione di JoomSport Standard (gratuita). In poche parole la prima query somma dei valori e la divide per la seconda query. Le variabili sono numeri interi; entrambe le select restituiscono un valore poiché provate singolarmente funzionano bene.
 
la query che hai postato non potrà mai funzionare,
abbiamo detto che l'operazione aritmetica si può fare su due valori, nel caso specifico dividendo e divisore,
quindi la costruzione della query deve essere
PHP:
SELECT
  SUM(me.count) / ( SELECT SUM(m.m_played) FROM ..... ) as cnt,
  CONCAT(pl.first_name,' ',pl.last_name) as name, 
  t.t_name,
  t.id as tid ,
  ev.e_img,
  ev.e_name,
  pl.id,
  pl.def_img 
FROM
ma potrebbe essere anche
PHP:
SELECT
  ( SUM(me.count) / SUM(m.m_played) ) as cnt,
  CONCAT(pl.first_name,' ',pl.last_name) as name, .....
se ho capito bene la necessità
ma lascio a te il compito di comporre il tutto
 

Discussioni simili