table_common_member_verify.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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_member_verify.php 28405 2012-02-29 03:47:50Z zhangguosheng $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_common_member_verify extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'common_member_verify';
  15. $this->_pk = 'uid';
  16. $this->_pre_cache_key = 'common_member_verify_';
  17. parent::__construct();
  18. }
  19. public function fetch_all_by_vid($vid, $flag, $uids = array()) {
  20. $parameter = array($this->_table);
  21. if($vid > 0 && $vid < 8) {
  22. $wherearr = array();
  23. if($uids) {
  24. $wherearr[] = is_array($uids) ? 'uid IN(%n)' : 'uid=%d';
  25. $parameter[] = $uids;
  26. }
  27. $parameter[] = $flag;
  28. $wherearr[] = "verify{$vid}=%d";
  29. return DB::fetch_all("SELECT * FROM %t WHERE ".implode(' AND ', $wherearr), $parameter, $this->_pk);
  30. } else {
  31. return array();
  32. }
  33. }
  34. public function fetch_all_search($uid, $vid, $username = '', $order = 'dateline', $start = 0, $limit = 0, $sort = 'DESC') {
  35. $condition = $this->search_condition($uid, $vid, $username);
  36. $ordersql = !empty($order) ? ' ORDER BY '.$order.' '.$sort : '';
  37. return DB::fetch_all("SELECT * FROM %t v, %t m $condition[0] $ordersql ".DB::limit($start, $limit), $condition[1], $this->_pk);
  38. }
  39. public function count_by_uid($uid) {
  40. return DB::result_first('SELECT COUNT(*) FROM %t WHERE uid=%d', array($this->_table, $uid));
  41. }
  42. public function count_by_search($uid, $vid, $username = '') {
  43. $condition = $this->search_condition($uid, $vid, $username);
  44. return DB::result_first('SELECT COUNT(*) FROM %t v, %t m '.$condition[0], $condition[1]);
  45. }
  46. public function search_condition($uid, $vid, $username) {
  47. $parameter = array($this->_table, 'common_member');
  48. $wherearr = array();
  49. if($uid) {
  50. $parameter[] = $uid;
  51. $wherearr[] = 'v.uid=%d';
  52. }
  53. if($vid > 0 && $vid < 8) {
  54. $parameter[] = $vid;
  55. $wherearr[] = 'v.verify%d=1';
  56. }
  57. if(!empty($username)) {
  58. $parameter[] = '%'.$username.'%';
  59. $wherearr[] = "m.username LIKE %s";
  60. }
  61. $wherearr[] = "v.uid=m.uid";
  62. $wheresql = !empty($wherearr) && is_array($wherearr) ? ' WHERE '.implode(' AND ', $wherearr) : '';
  63. return array($wheresql, $parameter);
  64. }
  65. }
  66. ?>