wfLimitResult() -> Database::limitResult()
[lhc/web/wiklou.git] / includes / SiteStatsUpdate.php
1 <?php
2 # $Id$
3 # See deferred.doc
4
5 class SiteStatsUpdate {
6
7 var $mViews, $mEdits, $mGood;
8
9 function SiteStatsUpdate( $views, $edits, $good )
10 {
11 $this->mViews = $views;
12 $this->mEdits = $edits;
13 $this->mGood = $good;
14 }
15
16 function doUpdate()
17 {
18 $a = array();
19
20 if ( $this->mViews < 0 ) { $m = "-1"; }
21 else if ( $this->mViews > 0 ) { $m = "+1"; }
22 else $m = "";
23 array_push( $a, "ss_total_views=(ss_total_views$m)" );
24
25 if ( $this->mEdits < 0 ) { $m = "-1"; }
26 else if ( $this->mEdits > 0 ) { $m = "+1"; }
27 else $m = "";
28 array_push( $a, "ss_total_edits=(ss_total_edits$m)" );
29
30 if ( $this->mGood < 0 ) { $m = "-1"; }
31 else if ( $this->mGood > 0 ) { $m = "+1"; }
32 else $m = "";
33 array_push( $a, "ss_good_articles=(ss_good_articles$m)" );
34
35 $db =& wfGetDB( DB_MASTER );
36 $site_stats = $db->tableName( 'site_stats' );
37 $lowpri = $db->lowPriorityOption();
38
39 $sql = "UPDATE $lowpri $site_stats SET " . implode ( ",", $a ) .
40 " WHERE ss_row_id=1";
41 $db->query( $sql, "SiteStatsUpdate::doUpdate" );
42 }
43 }
44
45 ?>