table_forum_order.php 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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_order.php 29009 2012-03-22 07:37:36Z chenmengshu $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_forum_order extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'forum_order';
  15. $this->_pk = 'orderid';
  16. parent::__construct();
  17. }
  18. public function count_by_search($uid = null, $status = null, $orderid = null, $email = null, $username = null, $buyer = null, $admin = null, $submit_starttime = null, $submit_endtime = null, $confirm_starttime = null, $confirm_endtime = null) {
  19. $sql = '';
  20. $sql .= $uid !== null ? ' AND o.'.DB::field('uid', dintval($uid)) : '';
  21. $sql .= $status ? ' AND o.'.DB::field('status', $status) : '';
  22. $sql .= $orderid ? ' AND o.'.DB::field('orderid', $orderid) : '';
  23. $sql .= $email ? ' AND o.'.DB::field('email', $email) : '';
  24. $sql .= $username ? ' AND m.'.DB::field('username', $username) : '';
  25. $sql .= $buyer ? ' AND o.'.DB::field('buyer', $buyer) : '';
  26. $sql .= $admin ? ' AND o.'.DB::field('admin', $admin) : '';
  27. $sql .= $submit_starttime ? ' AND o.'.DB::field('submitdate', $submit_starttime, '>=') : '';
  28. $sql .= $submit_endtime ? ' AND o.'.DB::field('submitdate', $submit_endtime, '<') : '';
  29. $sql .= $confirm_starttime ? ' AND o.'.DB::field('confirmdate', $confirm_starttime, '>=') : '';
  30. $sql .= $confirm_endtime ? ' AND o.'.DB::field('confirmdate', $confirm_endtime, '<') : '';
  31. return DB::result_first('SELECT COUNT(*) FROM %t o'.(($uid !== 0) ? ', '.DB::table('common_member').' m WHERE o.uid=m.uid' : ' WHERE 1 ').' %i', array($this->_table, $sql));
  32. }
  33. public function fetch_all_by_search($uid = null, $status = null, $orderid = null, $email = null, $username = null, $buyer = null, $admin = null, $submit_starttime = null, $submit_endtime = null, $confirm_starttime = null, $confirm_endtime = null, $start = null, $limit = null) {
  34. $sql = '';
  35. $sql .= $uid !== null ? ' AND o.'.DB::field('uid', dintval($uid)) : '';
  36. $sql .= $status ? ' AND o.'.DB::field('status', $status) : '';
  37. $sql .= $orderid ? ' AND o.'.DB::field('orderid', $orderid) : '';
  38. $sql .= $email ? ' AND o.'.DB::field('email', $email) : '';
  39. $sql .= $username ? ' AND m.'.DB::field('username', $username) : '';
  40. $sql .= $buyer ? ' AND o.'.DB::field('buyer', $buyer) : '';
  41. $sql .= $admin ? ' AND o.'.DB::field('admin', $admin) : '';
  42. $sql .= $submit_starttime ? ' AND o.'.DB::field('submitdate', $submit_starttime, '>=') : '';
  43. $sql .= $submit_endtime ? ' AND o.'.DB::field('submitdate', $submit_endtime, '<') : '';
  44. $sql .= $confirm_starttime ? ' AND o.'.DB::field('confirmdate', $confirm_starttime, '>=') : '';
  45. $sql .= $confirm_endtime ? ' AND o.'.DB::field('confirmdate', $confirm_endtime, '<') : '';
  46. return DB::fetch_all('SELECT o.*'.(($uid !== 0) ? ', m.username' : '').' FROM %t o'.(($uid !== 0) ? ', '.DB::table('common_member').' m WHERE o.uid=m.uid' : ' WHERE 1 ').' %i ORDER BY o.submitdate DESC '.DB::limit($start, $limit), array($this->_table, $sql));
  47. }
  48. public function fetch_all($orderid, $status = '') {
  49. if(empty($orderid)) {
  50. return array();
  51. }
  52. return DB::fetch_all('SELECT * FROM %t WHERE '.DB::field('orderid', $orderid).' %i', array($this->_table, ($status ? ' AND '.DB::field('status', $status) : '')));
  53. }
  54. public function delete_by_submitdate($submitdate) {
  55. return DB::query('DELETE FROM %t WHERE submitdate<%d', array($this->_table, $submitdate));
  56. }
  57. public function sum_amount_by_uid_submitdate_status($uid, $submitdate, $status) {
  58. if(empty($status)) {
  59. return 0;
  60. }
  61. return DB::result_first('SELECT SUM(amount) FROM %t WHERE uid=%d AND submitdate>=%d AND '.DB::field('status', $status), array($this->_table, $uid, $submitdate));
  62. }
  63. }
  64. ?>