www.lightcourse.com/app/common/model/Stat.php

506 lines
18 KiB
PHP

<?php
namespace app\common\model;
use think\facade\Db;
/**
* ============================================================================
* 联课教育商城系统
* ============================================================================
* 版权所有 2022 刻羽互动科技有限公司,并保留所有权利。
* 网站地址: http://www.o1h.cn
* ----------------------------------------------------------------------------
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
* 不允许对程序代码以任何形式任何目的的再发布。
* ============================================================================
* 数据层模型
*/
class Stat extends BaseModel
{
public $page_info;
/**
* 查询新增会员统计
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $field 字段
* @return array
*/
public function statByMember($where, $field = '*', $pagesize = 0, $order = '', $group = '')
{
if ($pagesize) {
$res = Db::name('member')->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();
}
}
}