_table = 'forum_order'; $this->_pk = 'orderid'; parent::__construct(); } 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) { $sql = ''; $sql .= $uid !== null ? ' AND o.'.DB::field('uid', dintval($uid)) : ''; $sql .= $status ? ' AND o.'.DB::field('status', $status) : ''; $sql .= $orderid ? ' AND o.'.DB::field('orderid', $orderid) : ''; $sql .= $email ? ' AND o.'.DB::field('email', $email) : ''; $sql .= $username ? ' AND m.'.DB::field('username', $username) : ''; $sql .= $buyer ? ' AND o.'.DB::field('buyer', $buyer) : ''; $sql .= $admin ? ' AND o.'.DB::field('admin', $admin) : ''; $sql .= $submit_starttime ? ' AND o.'.DB::field('submitdate', $submit_starttime, '>=') : ''; $sql .= $submit_endtime ? ' AND o.'.DB::field('submitdate', $submit_endtime, '<') : ''; $sql .= $confirm_starttime ? ' AND o.'.DB::field('confirmdate', $confirm_starttime, '>=') : ''; $sql .= $confirm_endtime ? ' AND o.'.DB::field('confirmdate', $confirm_endtime, '<') : ''; 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)); } 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) { $sql = ''; $sql .= $uid !== null ? ' AND o.'.DB::field('uid', dintval($uid)) : ''; $sql .= $status ? ' AND o.'.DB::field('status', $status) : ''; $sql .= $orderid ? ' AND o.'.DB::field('orderid', $orderid) : ''; $sql .= $email ? ' AND o.'.DB::field('email', $email) : ''; $sql .= $username ? ' AND m.'.DB::field('username', $username) : ''; $sql .= $buyer ? ' AND o.'.DB::field('buyer', $buyer) : ''; $sql .= $admin ? ' AND o.'.DB::field('admin', $admin) : ''; $sql .= $submit_starttime ? ' AND o.'.DB::field('submitdate', $submit_starttime, '>=') : ''; $sql .= $submit_endtime ? ' AND o.'.DB::field('submitdate', $submit_endtime, '<') : ''; $sql .= $confirm_starttime ? ' AND o.'.DB::field('confirmdate', $confirm_starttime, '>=') : ''; $sql .= $confirm_endtime ? ' AND o.'.DB::field('confirmdate', $confirm_endtime, '<') : ''; 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)); } public function fetch_all($orderid, $status = '') { if(empty($orderid)) { return array(); } return DB::fetch_all('SELECT * FROM %t WHERE '.DB::field('orderid', $orderid).' %i', array($this->_table, ($status ? ' AND '.DB::field('status', $status) : ''))); } public function delete_by_submitdate($submitdate) { return DB::query('DELETE FROM %t WHERE submitdate<%d', array($this->_table, $submitdate)); } public function sum_amount_by_uid_submitdate_status($uid, $submitdate, $status) { if(empty($status)) { return 0; } 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)); } } ?>