table_common_member_verify_info.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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_info.php 31799 2012-10-11 02:36:34Z zhengqingpeng $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_common_member_verify_info extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'common_member_verify_info';
  15. $this->_pk = 'vid';
  16. parent::__construct();
  17. }
  18. public function fetch_by_uid_verifytype($uid, $verifytype) {
  19. return DB::fetch_first('SELECT * FROM %t WHERE uid=%d AND verifytype=%d', array($this->_table, $uid, $verifytype));
  20. }
  21. public function fetch_all_search($uid, $vid, $flag = null, $username = '', $starttime = 0, $endtime = 0, $order = 'dateline', $start = 0, $limit = 0, $sort = 'DESC') {
  22. $condition = $this->search_condition($uid, $vid, $flag, $username, $starttime, $endtime);
  23. $ordersql = !empty($order) ? ' ORDER BY '.DB::order($order, $sort) : '';
  24. return DB::fetch_all("SELECT * FROM %t $condition[0] $ordersql ".DB::limit($start, $limit), $condition[1], $this->_pk);
  25. }
  26. public function group_by_verifytype_count() {
  27. return DB::fetch_all('SELECT verifytype, COUNT(*) AS num FROM %t WHERE flag=0 GROUP BY verifytype', array($this->_table));
  28. }
  29. public function delete_by_uid($uid, $verifytype = null) {
  30. if($uid) {
  31. $addsql = '';
  32. if($verifytype !== null) {
  33. $verifytype = dintval($verifytype, is_array($verifytype) ? true : false);
  34. $addsql = ' AND '.DB::field('verifytype', $verifytype);
  35. }
  36. return DB::fetch_first('DELETE FROM %t WHERE '.(is_array($uid) ? 'uid IN(%n)' : 'uid=%d').$addsql, array($this->_table, $uid));
  37. }
  38. return false;
  39. }
  40. public function count_by_search($uid, $vid, $flag = null, $username = '', $starttime = 0, $endtime = 0) {
  41. $condition = $this->search_condition($uid, $vid, $flag, $username, $starttime, $endtime);
  42. return DB::result_first('SELECT COUNT(*) FROM %t '.$condition[0], $condition[1]);
  43. }
  44. public function search_condition($uid, $vid, $flag, $username, $starttime, $endtime) {
  45. $parameter = array($this->_table);
  46. $wherearr = array();
  47. if($uid) {
  48. $parameter[] = $uid;
  49. $wherearr[] = 'uid=%d';
  50. }
  51. if($vid >= 0 && $vid < 8) {
  52. $parameter[] = $vid;
  53. $wherearr[] = 'verifytype=%d';
  54. }
  55. if($flag !== null) {
  56. $parameter[] = $flag;
  57. $wherearr[] = 'flag=%d';
  58. }
  59. if($starttime){
  60. $parameter[] = $starttime;
  61. $wherearr[] = 'dateline>=%d';
  62. }
  63. if($endtime){
  64. $parameter[] = $endtime;
  65. $wherearr[] = 'dateline<=%d';
  66. }
  67. if(!empty($username)) {
  68. $parameter[] = '%'.$username.'%';
  69. $wherearr[] = "username LIKE %s";
  70. }
  71. $wheresql = !empty($wherearr) && is_array($wherearr) ? ' WHERE '.implode(' AND ', $wherearr) : '';
  72. return array($wheresql, $parameter);
  73. }
  74. }
  75. ?>