table_common_stat.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. /**
  3. * [Discuz!] (C)2001-2099 Comsenz Inc.
  4. * This is NOT a freeware, use is subject to license terms
  5. *
  6. * $Id: table_common_stat.php 28051 2012-02-21 10:36:56Z zhangguosheng $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_common_stat extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'common_stat';
  15. $this->_pk = 'daytime';
  16. parent::__construct();
  17. }
  18. public function updatestat($uid, $type, $primary = 0, $num = 1) {
  19. $nowdaytime = dgmdate(TIMESTAMP, 'Ymd');
  20. $type = addslashes($type);
  21. if($primary) {
  22. $setarr = array(
  23. 'uid' => intval($uid),
  24. 'daytime' => $nowdaytime,
  25. 'type' => $type
  26. );
  27. if(C::t('common_statuser')->check_exists($uid, $nowdaytime, $type)) {
  28. return false;
  29. } else {
  30. C::t('common_statuser')->insert($setarr);
  31. }
  32. }
  33. $num = abs(intval($num));
  34. if(DB::result_first('SELECT COUNT(*) FROM '.DB::table($this->_table)." WHERE `daytime` = '$nowdaytime'")){
  35. DB::query('UPDATE '.DB::table($this->_table)." SET `$type`=`$type`+$num WHERE `daytime` = '$nowdaytime'");
  36. } else {
  37. C::t('common_statuser')->clear_by_daytime($nowdaytime);
  38. DB::insert($this->_table, array('daytime'=>$nowdaytime, $type=>$num));
  39. }
  40. }
  41. public function fetch_post_avg() {
  42. return DB::result_first("SELECT AVG(post) FROM ".DB::table($this->_table));
  43. }
  44. public function fetch_all($begin, $end, $field = '*') {
  45. $data = array();
  46. $query = DB::query('SELECT %i FROM %t WHERE daytime>=%d AND daytime<=%d ORDER BY daytime', array($field, $this->_table, $begin, $end));
  47. while($value = DB::fetch($query)) {
  48. $data[$value['daytime']] = $value;
  49. }
  50. return $data;
  51. }
  52. public function fetch_all_by_daytime($daytime, $start = 0, $limit = 0, $sort = 'ASC') {
  53. $wheresql = '';
  54. $parameter = array($this->_table);
  55. if($daytime) {
  56. $wheresql = 'WHERE daytime>=%d';
  57. $parameter[] = $daytime;
  58. }
  59. return DB::fetch_all("SELECT * FROM %t $wheresql ORDER BY daytime $sort".DB::limit($start, $limit), $parameter);
  60. }
  61. }
  62. ?>