table_forum_collectionfollow.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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_forum_collectionfollow.php 27781 2012-02-14 07:38:55Z zhengqingpeng $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_forum_collectionfollow extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'forum_collectionfollow';
  15. $this->_pk = 'ctid';
  16. parent::__construct();
  17. }
  18. public function fetch_all($ctid, $order = false, $start = 0, $limit = 0) {
  19. if(!$ctid) {
  20. return null;
  21. }
  22. $sql = DB::field('ctid', $ctid);
  23. if($order) {
  24. $sql .= ' ORDER BY '.DB::order('dateline', 'DESC');
  25. }
  26. if($limit) {
  27. $sql .= DB::limit($start, $limit);
  28. }
  29. return DB::fetch_all('SELECT * FROM %t WHERE '.$sql, array($this->_table));
  30. }
  31. public function fetch_all_by_uid($uid) {
  32. if(!$uid) {
  33. return null;
  34. }
  35. return DB::fetch_all('SELECT * FROM %t WHERE %i', array($this->_table, DB::field('uid', $uid)), $this->_pk);
  36. }
  37. public function fetch_by_ctid_uid($ctid, $uid) {
  38. return DB::fetch_first('SELECT * FROM %t WHERE uid=%d AND ctid=%d', array($this->_table, $uid, $ctid));
  39. }
  40. public function delete_by_ctid($ctid) {
  41. if(!$ctid) {
  42. return false;
  43. }
  44. return DB::delete($this->_table, DB::field('ctid', $ctid));
  45. }
  46. public function delete_by_ctid_uid($ctid, $uid) {
  47. return DB::query("DELETE FROM %t WHERE uid=%d AND ctid=%d", array($this->_table, $uid, $ctid));
  48. }
  49. public function delete_by_uid($uid) {
  50. if(!$uid) {
  51. return false;
  52. }
  53. return DB::query("DELETE FROM %t WHERE %i", array($this->_table, DB::field('uid', $uid)));
  54. }
  55. public function count_by_ctid_uid($uid, $ctid) {
  56. return DB::result_first('SELECT COUNT(*) FROM %t WHERE uid=%d AND ctid=%d', array($this->_table, $uid, $ctid), $this->_pk);
  57. }
  58. public function count_by_uid($uid) {
  59. return DB::result_first('SELECT COUNT(*) FROM %t WHERE uid=%d', array($this->_table, $uid));
  60. }
  61. public function update($ctid, $uid, $data, $unbuffered = false, $low_priority = false) {
  62. if(!empty($data) && is_array($data) && $ctid && $uid) {
  63. return DB::update($this->_table, $data, DB::field('ctid', $ctid).' AND '.DB::field('uid', $uid), $unbuffered, $low_priority);
  64. }
  65. return !$unbuffered ? 0 : false;
  66. }
  67. }
  68. ?>