table_home_visitor.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  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_home_visitor.php 31354 2012-08-16 03:03:08Z chenmengshu $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_home_visitor extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'home_visitor';
  15. $this->_pk = '';
  16. parent::__construct();
  17. }
  18. public function fetch_by_uid_vuid($uid, $vuid) {
  19. return DB::fetch_first('SELECT * FROM %t WHERE uid=%d AND vuid=%d', array($this->_table, $uid, $vuid));
  20. }
  21. public function fetch_all_by_uid($uid, $start = 0, $limit = 0) {
  22. return DB::fetch_all('SELECT * FROM %t WHERE uid=%d ORDER BY dateline DESC '.DB::limit($start, $limit), array($this->_table, $uid));
  23. }
  24. public function fetch_all_by_vuid($uid, $start = 0, $limit = 0) {
  25. return DB::fetch_all('SELECT * FROM %t WHERE vuid=%d ORDER BY dateline DESC '.DB::limit($start, $limit), array($this->_table, $uid));
  26. }
  27. public function update_by_uid_vuid($uid, $vuid, $data) {
  28. $uid = dintval($uid, true);
  29. $vuid = dintval($vuid, true);
  30. if($uid && !empty($data) && is_array($data)) {
  31. return DB::update($this->_table, $data, DB::field('uid', $uid).' AND '.DB::field('vuid', $vuid));
  32. }
  33. return 0;
  34. }
  35. public function delete_by_uid_or_vuid($uids) {
  36. $uids = dintval($uids, true);
  37. if($uids) {
  38. return DB::delete($this->_table, DB::field('uid', $uids).' OR '.DB::field('vuid', $uids));
  39. }
  40. return 0;
  41. }
  42. public function delete_by_uid_vuid($uid, $vuid) {
  43. $uid = dintval($uid);
  44. $vuid = dintval($vuid);
  45. return DB::delete($this->_table, DB::field('uid', $uid).' AND '.DB::field('vuid', $vuid));
  46. }
  47. public function delete_by_dateline($dateline) {
  48. $dateline = dintval($dateline);
  49. return DB::delete($this->_table, DB::field('dateline', $dateline, '<'));
  50. }
  51. public function count_by_uid($uid) {
  52. return DB::result_first('SELECT COUNT(*) FROM %t WHERE uid=%d', array($this->_table,$uid));
  53. }
  54. public function count_by_vuid($uid) {
  55. return DB::result_first('SELECT COUNT(*) FROM %t WHERE vuid=%d', array($this->_table,$uid));
  56. }
  57. }
  58. ?>