field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); } else { return Db::name('member')->field($field)->where($where)->page($pagesize)->order($order)->group($group)->select()->toArray(); } } /** * 查询单条会员统计 * @access public * @author o1h.cn * @param array $where 条件 * @param string $field 字段 * @param string $order 排序 * @param string $group 分组 * @return array */ public function getOneByMember($where, $field = '*', $order = '', $group = '') { return Db::name('member')->field($field)->where($where)->order($order)->group($group)->find(); } /** * 查询会员列表 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $order 排序 * @return type */ public function getMemberList($where, $field = '*', $pagesize = 0, $order = 'member_id desc') { if($pagesize){ $res = Db::name('member')->field($field)->where($where)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('member')->field($field)->where($where)->order($order)->select()->toArray(); } } /** * 查询会员统计数据记录 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return array */ public function statByStatmember($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if($pagesize){ $res = Db::name('statmember')->field($field)->where($where)->limit($limit)->order($order)->group($group)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('statmember')->field($field)->where($where)->limit($limit)->order($order)->group($group)->select()->toArray(); } } /** * 查询商品数量 * @access public * @author o1h.cn * @param type $where 条件 * @return type */ public function getGoodsNum($where) { $rs = Db::name('goodscommon')->field('count(*) as allnum')->where($where)->select()->toArray(); return $rs[0]['allnum']; } /** * 获取预存款数据 * @access public * @author o1h.cn * @param type $condition 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $order 排序 * @param type $limit 限制 * @param type $group 分组 * @return type */ public function getPredepositInfo($condition, $field = '*', $pagesize = 0, $order = 'lg_addtime desc', $limit = 0, $group = '') { if ($pagesize) { $res = Db::name('pdlog')->field($field)->where($condition)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); } else { return Db::name('pdlog')->field($field)->where($condition)->group($group)->order($order)->limit($limit)->select()->toArray(); } } /** * 查询订单及订单商品的统计 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return type */ public function statByOrderGoods($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if($pagesize){ $res = Db::name('ordergoods')->alias('ordergoods')->field($field)->join('order order', 'ordergoods.order_id=order.order_id', 'left')->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('ordergoods')->alias('ordergoods')->field($field)->join('order order', 'ordergoods.order_id=order.order_id', 'left')->where($where)->group($group)->order($order)->select()->toArray(); } } /** * 查询订单及订单商品的统计 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return type */ public function statByOrderLog($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if($pagesize){ $res = Db::name('orderlog')->alias('orderlog')->field($field)->join('order order', 'orderlog.order_id = order.order_id', 'left')->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('orderlog')->alias('orderlog')->field($field)->join('order order', 'orderlog.order_id = order.order_id', 'left')->where($where)->group($group)->order($order)->select()->toArray(); } } /** * 查询退款退货统计 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return type */ public function statByRefundreturn($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if ($pagesize) { $res = Db::name('refundreturn')->field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); } else { return Db::name('refundreturn')->field($field)->where($where)->group($group)->order($order)->limit($limit)->select()->toArray(); } } /** * 处理搜索时间 * @access public * @author o1h.cn * @param type $search_arr 搜索数组 * @return type */ public function dealwithSearchTime($search_arr) { //初始化时间 //天 if (!isset($search_arr['search_time'])) { $search_arr['search_time'] = date('Y-m-d', TIMESTAMP - 86400); } $search_arr['day']['search_time'] = strtotime($search_arr['search_time']); //搜索的时间 //周 if (!isset($search_arr['searchweek_year'])) { $search_arr['searchweek_year'] = date('Y', TIMESTAMP); } if (!isset($search_arr['searchweek_month'])) { $search_arr['searchweek_month'] = date('m', TIMESTAMP); } if (!isset($search_arr['searchweek_week'])) { $search_arr['searchweek_week'] = implode('|', getWeek_SdateAndEdate(TIMESTAMP)); } $weekcurrent_year = $search_arr['searchweek_year']; $weekcurrent_month = $search_arr['searchweek_month']; $weekcurrent_week = $search_arr['searchweek_week']; $search_arr['week']['current_year'] = $weekcurrent_year; $search_arr['week']['current_month'] = $weekcurrent_month; $search_arr['week']['current_week'] = $weekcurrent_week; //月 if (!isset($search_arr['searchmonth_year'])) { $search_arr['searchmonth_year'] = date('Y', TIMESTAMP); } if (!isset($search_arr['searchmonth_month'])) { $search_arr['searchmonth_month'] = date('m', TIMESTAMP); } $monthcurrent_year = $search_arr['searchmonth_year']; $monthcurrent_month = $search_arr['searchmonth_month']; $search_arr['month']['current_year'] = $monthcurrent_year; $search_arr['month']['current_month'] = $monthcurrent_month; return $search_arr; } /** * 获得查询的开始和结束时间 * @access public * @author o1h.cn * @param type $search_arr 搜索数组 * @return type */ public function getStarttimeAndEndtime($search_arr) { $stime=array(); $etime=array(); if (isset($search_arr['search_type'])&&$search_arr['search_type'] == 'day') { $stime = $search_arr['day']['search_time']; //今天0点 $etime = $search_arr['day']['search_time'] + 86400 - 1; //今天24点 } if (isset($search_arr['search_type'])&&$search_arr['search_type'] == 'week') { $current_weekarr = explode('|', $search_arr['week']['current_week']); $stime = strtotime($current_weekarr[0]); $etime = strtotime($current_weekarr[1]) + 86400 - 1; } if (isset($search_arr['search_type'])&&$search_arr['search_type'] == 'month') { $stime = strtotime($search_arr['month']['current_year'] . '-' . $search_arr['month']['current_month'] . "-01 0 month"); $etime = getMonthLastDay($search_arr['month']['current_year'], $search_arr['month']['current_month']) + 86400 - 1; } return array($stime, $etime); } /** * 查询会员统计数据单条记录 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $order 排序 * @param type $group 分组 * @return type */ public function getOneStatmember($where, $field = '*', $order = '', $group = '') { return Db::name('statmember')->field($field)->where($where)->group($group)->order($order)->find(); } /** * 更新会员统计数据单条记录 * @access public * @author o1h.cn * @param type $where 条件 * @param type $update_arr 更新数据 * @return type */ public function editStatmember($where, $update_arr) { return Db::name('statmember')->where($where)->update($update_arr); } /** * 查询订单的统计 * @access public * @author o1h.cn * @param array $where 条件 * @param string $field 字段 * @param int $pagesize 分页 * @param int $limit 限制 * @param string $order 排序 * @return array */ public function statByOrder($where, $field = '*', $pagesize = 0, $limit = 0, $order = '') { if($pagesize){ $res = Db::name('order')->field($field)->where($where)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('order')->field($field)->where($where)->order($order)->select()->toArray(); } } /** * 查询积分的统计 * @access public * @author o1h.cn * @param array $where 条件 * @param string $field 字段 * @param int $pagesize 分页 * @param int $limit 限制 * @param string $order 排序 * @param string $group 分组 */ public function statByPointslog($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if($pagesize){ $res = Db::name('pointslog')->field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('pointslog')->field($field)->where($where)->group($group)->order($order)->select()->toArray(); } } /** * 删除会员统计数据记录 * @access public * @author o1h.cn * @param type $where 条件数组 */ public function delByStatmember($where = array()) { Db::name('statmember')->where($where)->delete(); } /** * 查询订单商品缓存的统计 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $order 排序 * @param type $group 分组 * @return type */ public function getoneByStatordergoods($where, $field = '*', $order = '', $group = '') { return Db::name('statordergoods')->field($field)->where($where)->group($group)->order($order)->find(); } /** * 查询订单商品缓存的统计 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return type */ public function statByStatordergoods($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if ($pagesize) { $res = Db::name('statordergoods')->field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); } else { return Db::name('statordergoods')->field($field)->where($where)->group($group)->order($order)->limit($limit)->select()->toArray(); } } /** * 查询订单缓存的统计 * @access public * @author o1h.cn * @param array $where 条件 * @param string $field 字段 * @param string $order 排序 * @param string $group 分组 * @return array */ public function getoneByStatorder($where, $field = '*', $order = '', $group = '') { return Db::name('statorder')->field($field)->where($where)->group($group)->order($order)->find(); } /** * 查询订单缓存的统计 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return type */ public function statByStatorder($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if ($pagesize) { $res = Db::name('statorder')->field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); } else { return Db::name('statorder')->field($field)->where($where)->group($group)->order($order)->limit($limit)->select()->toArray(); } } /** * 查询商品列表 * @access public * @author o1h.cn * @param type $where 条件 * @param type $field 字段 * @param type $pagesize 分页 * @param type $limit 限制 * @param type $order 排序 * @param type $group 分组 * @return type */ public function statByGoods($where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if($pagesize){ $res = Db::name('goods')->field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); }else{ return Db::name('goods')->field($field)->where($where)->group($group)->order($order)->select()->toArray(); } } /** * 查询流量统计单条记录 * @access public * @author o1h.cn * @param type $tablename 表名 * @param type $where 条件 * @param type $field 字段 * @param type $order 排序 * @param type $group 分组 * @return type */ public function getoneByFlowstat($tablename = 'flowstat', $where, $field = '*', $order = '', $group = '') { return Db::name($tablename)->field($field)->where($where)->group($group)->order($order)->find(); } /** * 查询流量统计记录 * @access public * @author o1h.cn * @param string $tablename 表名 * @param array $where 条件 * @param string $field 字段 * @param int $pagesize 分页 * @param int $limit 限制 * @param string $order 排序 * @param string $group 分组 * @return array */ public function statByFlowstat($tablename = 'flowstat', $where, $field = '*', $pagesize = 0, $limit = 0, $order = '', $group = '') { if ($pagesize) { $res = Db::name($tablename)->field($field)->where($where)->group($group)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false); $this->page_info = $res; return $res->items(); } else { return Db::name($tablename)->field($field)->where($where)->group($group)->order($order)->limit($limit)->select()->toArray(); } } }