table_forum_collectionthread.php 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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_collectionthread.php 34219 2013-11-14 08:09:32Z jeffjzhang $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_forum_collectionthread extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'forum_collectionthread';
  15. $this->_pk = '';
  16. parent::__construct();
  17. }
  18. public function fetch_all_by_ctid($ctid, $start = 0, $limit = 0, $distinct = 0) {
  19. if(!$ctid) {
  20. return null;
  21. }
  22. if($distinct == 1) {
  23. $sql = " GROUP BY tid";
  24. }
  25. return DB::fetch_all('SELECT * FROM %t WHERE '.DB::field('ctid', $ctid).$sql.' ORDER BY dateline DESC '.DB::limit($start, $limit), array($this->_table), 'tid');
  26. }
  27. public function fetch_by_ctid_dateline($ctid) {
  28. $data = $this->fetch_all_by_ctid($ctid, 0, 1);
  29. return $data ? current($data) : null;
  30. }
  31. public function fetch_all_by_tids($tids) {
  32. if(!$tids) {
  33. return null;
  34. }
  35. return DB::fetch_all('SELECT * FROM %t WHERE '.DB::field('tid', $tids), array($this->_table), 'ctid');
  36. }
  37. public function fetch_by_ctid_tid($ctid, $tid) {
  38. return DB::fetch_first('SELECT * FROM %t WHERE ctid=%d AND tid=%d', array($this->_table, $ctid, $tid));
  39. }
  40. public function fetch_all_by_ctid_tid($ctid, $tids) {
  41. if(!$ctid || !$tids) {
  42. return null;
  43. }
  44. return DB::fetch_all('SELECT * FROM %t WHERE ctid=%d AND tid IN(%n)', array($this->_table, $ctid, $tids), 'tid');
  45. }
  46. public function delete_by_ctid($ctid) {
  47. if(!$ctid) {
  48. return false;
  49. }
  50. return DB::delete($this->_table, DB::field('ctid', $ctid));
  51. }
  52. public function delete_by_ctid_tid($ctid, $tid) {
  53. if(!$ctid && !$tid) {
  54. return false;
  55. }
  56. $condition = array();
  57. if($ctid) {
  58. $condition[] = DB::field('ctid', $ctid);
  59. }
  60. if($tid) {
  61. $condition[] = DB::field('tid', $tid);
  62. }
  63. return DB::delete($this->_table, implode(' AND ', $condition), 0, false);
  64. }
  65. }
  66. ?>