2019-02-22 18:38:11 +08:00
< ? php
// +----------------------------------------------------------------------
// | ShopXO 国内领先企业级B2C免费开源电商系统
// +----------------------------------------------------------------------
2021-03-16 10:34:52 +08:00
// | Copyright (c) 2011~2099 http://shopxo.net All rights reserved.
2019-02-22 18:38:11 +08:00
// +----------------------------------------------------------------------
2021-03-16 10:34:52 +08:00
// | Licensed ( https://opensource.org/licenses/mit-license.php )
2019-02-22 18:38:11 +08:00
// +----------------------------------------------------------------------
// | Author: Devil
// +----------------------------------------------------------------------
namespace app\service ;
2021-07-18 23:42:10 +08:00
use think\facade\Db ;
2019-02-22 18:38:11 +08:00
/**
* 数据统计服务层
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 01 T21 : 51 : 08 + 0800
*/
class StatisticalService
{
// 近3天,近7天,近15天,近30天
2021-08-31 16:06:01 +08:00
public static $nearly_three_days ;
public static $nearly_seven_days ;
public static $nearly_fifteen_days ;
public static $nearly_thirty_days ;
// 昨天
public static $yesterday_time_start ;
public static $yesterday_time_end ;
// 今天
public static $today_time_start ;
public static $today_time_end ;
2019-02-22 18:38:11 +08:00
2021-09-01 14:21:42 +08:00
// 近365天
public static $year_time_start ;
public static $year_time_end ;
// 近180天
public static $half_year_time_start ;
public static $half_year_time_end ;
2020-09-24 19:09:05 +08:00
// 近30天
2021-08-31 16:06:01 +08:00
public static $thirty_time_start ;
public static $thirty_time_end ;
2019-08-18 12:12:47 +08:00
2020-09-24 19:09:05 +08:00
// 近15天
2021-08-31 16:06:01 +08:00
public static $fifteen_time_start ;
public static $fifteen_time_end ;
2019-08-15 18:56:05 +08:00
2020-09-24 19:09:05 +08:00
// 近7天
2021-08-31 16:06:01 +08:00
public static $seven_time_start ;
public static $seven_time_end ;
// 近3天
public static $three_time_start ;
public static $three_time_end ;
2019-02-23 08:41:27 +08:00
2020-09-24 19:09:05 +08:00
// 上月
2021-08-31 16:06:01 +08:00
public static $last_month_time_start ;
public static $last_month_time_end ;
2020-09-24 19:09:05 +08:00
// 当月
2021-08-31 16:06:01 +08:00
public static $this_month_time_start ;
public static $this_month_time_end ;
2020-09-24 19:09:05 +08:00
2021-08-31 16:06:01 +08:00
// 去年
public static $this_year_time_start ;
public static $this_year_time_end ;
2019-02-22 18:38:11 +08:00
2021-08-31 16:06:01 +08:00
// 今年
public static $last_year_time_start ;
public static $last_year_time_end ;
2019-02-22 18:38:11 +08:00
/**
* 初始化
* @ author Devil
* @ blog http :// gong . gg /
* @ version 1.0 . 0
* @ date 2019 - 02 - 22
* @ desc description
* @ param [ array ] $params [ 输入参数 ]
*/
public static function Init ( $params = [])
{
2019-02-23 10:04:40 +08:00
static $object = null ;
if ( ! is_object ( $object ))
{
// 初始化标记对象,避免重复初始化
$object = ( object ) [];
2019-02-23 08:41:27 +08:00
2021-08-31 16:06:01 +08:00
// 昨天日期
self :: $yesterday_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-1 day' )));
self :: $yesterday_time_end = strtotime ( date ( 'Y-m-d 23:59:59' , strtotime ( '-1 day' )));
// 今天日期
self :: $today_time_start = strtotime ( date ( 'Y-m-d 00:00:00' ));
self :: $today_time_end = time ();
2021-09-01 14:21:42 +08:00
// 近365天日期
self :: $year_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-365 day' )));
self :: $year_time_end = time ();
// 近180天日期
self :: $half_year_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-180 day' )));
self :: $half_year_time_end = time ();
2019-08-18 12:12:47 +08:00
// 近30天日期
2021-08-31 16:06:01 +08:00
self :: $thirty_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-29 day' )));
2019-08-18 12:12:47 +08:00
self :: $thirty_time_end = time ();
// 近15天日期
2021-08-31 16:06:01 +08:00
self :: $fifteen_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-14 day' )));
2019-08-15 18:56:05 +08:00
self :: $fifteen_time_end = time ();
2019-02-23 10:04:40 +08:00
// 近7天日期
2021-08-31 16:06:01 +08:00
self :: $seven_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-6 day' )));
2019-02-23 10:04:40 +08:00
self :: $seven_time_end = time ();
2019-02-22 18:38:11 +08:00
2021-08-31 16:06:01 +08:00
// 近3天日期
self :: $three_time_start = strtotime ( date ( 'Y-m-d 00:00:00' , strtotime ( '-2 day' )));
self :: $three_time_end = time ();
2020-09-24 19:09:05 +08:00
// 上月
2021-04-07 14:17:35 +08:00
self :: $last_month_time_start = strtotime ( date ( 'Y-m-01 00:00:00' , strtotime ( '-1 month' , strtotime ( date ( 'Y-m' , time ())))));
self :: $last_month_time_end = strtotime ( date ( 'Y-m-t 23:59:59' , strtotime ( '-1 month' , strtotime ( date ( 'Y-m' , time ())))));
2020-09-24 19:09:05 +08:00
// 当月
2021-08-31 16:06:01 +08:00
self :: $this_month_time_start = strtotime ( date ( 'Y-m-01 00:00:00' ));
self :: $this_month_time_end = time ();
2020-09-24 19:09:05 +08:00
2021-08-31 16:06:01 +08:00
// 去年
self :: $last_year_time_start = strtotime ( date ( 'Y-01-01 00:00:00' , strtotime ( '-1 year' , strtotime ( date ( 'Y-m' , time ())))));
self :: $last_year_time_end = strtotime ( date ( 'Y-12-31 23:59:59' , strtotime ( '-1 year' , strtotime ( date ( 'Y-m' , time ())))));
// 今年
self :: $this_year_time_start = strtotime ( date ( 'Y-01-01 00:00:00' ));
self :: $this_year_time_end = time ();
2019-02-22 18:38:11 +08:00
2019-02-23 10:04:40 +08:00
// 近3天,近7天,近15天,近30天
$nearly_all = [
3 => 'nearly_three_days' ,
7 => 'nearly_seven_days' ,
15 => 'nearly_fifteen_days' ,
30 => 'nearly_thirty_days' ,
];
foreach ( $nearly_all as $day => $name )
2019-02-22 18:38:11 +08:00
{
2019-02-23 10:04:40 +08:00
$date = [];
$time = time ();
for ( $i = 0 ; $i < $day ; $i ++ )
{
$date [] = [
'start_time' => strtotime ( date ( 'Y-m-d 00:00:00' , time () - $i * 3600 * 24 )),
'end_time' => strtotime ( date ( 'Y-m-d 23:59:59' , time () - $i * 3600 * 24 )),
'name' => date ( 'Y-m-d' , time () - $i * 3600 * 24 ),
];
}
2019-08-15 18:56:05 +08:00
self :: ${$name} = array_reverse ( $date );
2019-02-22 18:38:11 +08:00
}
}
}
2019-02-23 08:41:27 +08:00
2021-08-31 16:06:01 +08:00
/**
* 获取时间列表
* @ author Devil
* @ blog http :// gong . gg /
* @ version 1.0 . 0
* @ date 2021 - 08 - 31
* @ desc description
* @ param [ array ] $params [ 数据参数 ]
*/
public static function DateTimeList ( $params = [])
{
// 初始化
self :: Init ( $params );
// 统计时间配置列表
return [
'3-day' => [
2024-07-03 22:46:04 +08:00
'key' => '3-day' ,
'name' => MyLang ( 'common_service.statistical.time_section_day_3_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $three_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $three_time_end ),
2021-08-31 16:06:01 +08:00
],
'7-day' => [
2024-07-03 22:46:04 +08:00
'key' => '7-day' ,
'name' => MyLang ( 'common_service.statistical.time_section_day_7_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $seven_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $seven_time_end ),
2021-08-31 16:06:01 +08:00
],
2024-07-03 22:46:04 +08:00
'15-day' => [
'key' => '15-day' ,
'name' => MyLang ( 'common_service.statistical.time_section_day_15_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $fifteen_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $fifteen_time_end ),
2021-08-31 16:06:01 +08:00
],
2024-07-03 22:46:04 +08:00
'30-day' => [
'key' => '30-day' ,
'name' => MyLang ( 'common_service.statistical.time_section_day_30_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $thirty_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $thirty_time_end ),
2021-08-31 16:06:01 +08:00
],
2024-07-03 22:46:04 +08:00
'180-day' => [
'key' => '180-day' ,
'name' => MyLang ( 'common_service.statistical.time_section_day_180_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $half_year_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $half_year_time_end ),
2021-09-01 14:21:42 +08:00
],
2024-07-03 22:46:04 +08:00
'365-day' => [
'key' => '365-day' ,
'name' => MyLang ( 'common_service.statistical.time_section_day_365_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $year_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $year_time_end ),
2021-09-01 14:21:42 +08:00
],
2024-07-03 22:46:04 +08:00
'this-month' => [
'key' => 'this-month' ,
'name' => MyLang ( 'common_service.statistical.time_section_this_month_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $this_month_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $this_month_time_end ),
2021-08-31 16:06:01 +08:00
],
2024-07-03 22:46:04 +08:00
'last-month' => [
'key' => 'last-month' ,
'name' => MyLang ( 'common_service.statistical.time_section_last_month_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $last_month_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $last_month_time_end ),
2021-08-31 16:06:01 +08:00
],
'this-year' => [
2024-07-03 22:46:04 +08:00
'key' => 'this-year' ,
'name' => MyLang ( 'common_service.statistical.time_section_this_year_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $this_year_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $this_year_time_end ),
2021-08-31 16:06:01 +08:00
],
'last-year' => [
2024-07-03 22:46:04 +08:00
'key' => 'last-year' ,
'name' => MyLang ( 'common_service.statistical.time_section_last_year_name' ),
'start' => date ( 'Y-m-d H:i:s' , StatisticalService :: $last_year_time_start ),
'end' => date ( 'Y-m-d H:i:s' , StatisticalService :: $last_year_time_end ),
2021-08-31 16:06:01 +08:00
],
];
}
2019-02-22 18:38:11 +08:00
/**
2020-09-24 19:09:05 +08:00
* 用户总数 , 今日 , 昨日 , 当月 , 上月总数
2019-02-22 18:38:11 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function UserYesterdayTodayTotal ( $params = [])
{
// 初始化
self :: Init ( $params );
2020-09-24 19:09:05 +08:00
// 上月
$where = [
[ 'add_time' , '>=' , self :: $last_month_time_start ],
[ 'add_time' , '<=' , self :: $last_month_time_end ],
];
$last_month_count = Db :: name ( 'User' ) -> where ( $where ) -> count ();
// 当月
$where = [
2021-08-31 16:06:01 +08:00
[ 'add_time' , '>=' , self :: $this_month_time_start ],
[ 'add_time' , '<=' , self :: $this_month_time_end ],
2020-09-24 19:09:05 +08:00
];
$same_month_count = Db :: name ( 'User' ) -> where ( $where ) -> count ();
2019-02-22 18:38:11 +08:00
// 昨天
$where = [
[ 'add_time' , '>=' , self :: $yesterday_time_start ],
[ 'add_time' , '<=' , self :: $yesterday_time_end ],
];
$yesterday_count = Db :: name ( 'User' ) -> where ( $where ) -> count ();
// 今天
$where = [
[ 'add_time' , '>=' , self :: $today_time_start ],
[ 'add_time' , '<=' , self :: $today_time_end ],
];
$today_count = Db :: name ( 'User' ) -> where ( $where ) -> count ();
// 数据组装
2019-02-23 08:41:27 +08:00
$result = [
2020-09-24 19:09:05 +08:00
'last_month_count' => $last_month_count ,
'same_month_count' => $same_month_count ,
2019-02-23 08:41:27 +08:00
'yesterday_count' => $yesterday_count ,
'today_count' => $today_count ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-23 08:41:27 +08:00
}
/**
2020-09-24 19:09:05 +08:00
* 订单总数 , 今日 , 昨日 , 当月 , 上月总数
2019-02-23 08:41:27 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function OrderNumberYesterdayTodayTotal ( $params = [])
{
// 初始化
self :: Init ( $params );
// 订单状态
// ( 0待确认, 1已确认/待支付, 2已支付/待发货, 3已发货/待收货, 4已完成, 5已取消, 6已关闭)
2020-09-24 19:09:05 +08:00
// 上月
$where = [
[ 'status' , '<=' , 4 ],
[ 'add_time' , '>=' , self :: $last_month_time_start ],
[ 'add_time' , '<=' , self :: $last_month_time_end ],
];
$last_month_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
// 当月
$where = [
[ 'status' , '<=' , 4 ],
2021-08-31 16:06:01 +08:00
[ 'add_time' , '>=' , self :: $this_month_time_start ],
[ 'add_time' , '<=' , self :: $this_month_time_end ],
2020-09-24 19:09:05 +08:00
];
$same_month_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
2019-02-23 08:41:27 +08:00
// 昨天
$where = [
[ 'status' , '<=' , 4 ],
[ 'add_time' , '>=' , self :: $yesterday_time_start ],
[ 'add_time' , '<=' , self :: $yesterday_time_end ],
];
$yesterday_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
// 今天
$where = [
[ 'status' , '<=' , 4 ],
[ 'add_time' , '>=' , self :: $today_time_start ],
[ 'add_time' , '<=' , self :: $today_time_end ],
];
$today_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
// 数据组装
$result = [
2020-09-24 19:09:05 +08:00
'last_month_count' => $last_month_count ,
'same_month_count' => $same_month_count ,
2019-02-23 08:41:27 +08:00
'yesterday_count' => $yesterday_count ,
'today_count' => $today_count ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-23 08:41:27 +08:00
}
/**
2020-09-24 19:09:05 +08:00
* 订单成交总量 , 今日 , 昨日 , 当月 , 上月总数
2019-02-23 08:41:27 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function OrderCompleteYesterdayTodayTotal ( $params = [])
{
// 初始化
self :: Init ( $params );
// 订单状态
// ( 0待确认, 1已确认/待支付, 2已支付/待发货, 3已发货/待收货, 4已完成, 5已取消, 6已关闭)
2020-09-24 19:09:05 +08:00
// 上月
$where = [
[ 'status' , '=' , 4 ],
[ 'add_time' , '>=' , self :: $last_month_time_start ],
[ 'add_time' , '<=' , self :: $last_month_time_end ],
];
$last_month_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
// 当月
$where = [
[ 'status' , '=' , 4 ],
2021-08-31 16:06:01 +08:00
[ 'add_time' , '>=' , self :: $this_month_time_start ],
[ 'add_time' , '<=' , self :: $this_month_time_end ],
2020-09-24 19:09:05 +08:00
];
$same_month_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
2019-02-23 08:41:27 +08:00
// 昨天
$where = [
[ 'status' , '=' , 4 ],
[ 'add_time' , '>=' , self :: $yesterday_time_start ],
[ 'add_time' , '<=' , self :: $yesterday_time_end ],
];
$yesterday_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
// 今天
$where = [
[ 'status' , '=' , 4 ],
[ 'add_time' , '>=' , self :: $today_time_start ],
[ 'add_time' , '<=' , self :: $today_time_end ],
];
$today_count = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
// 数据组装
$result = [
2020-09-24 19:09:05 +08:00
'last_month_count' => $last_month_count ,
'same_month_count' => $same_month_count ,
2019-02-22 18:38:11 +08:00
'yesterday_count' => $yesterday_count ,
'today_count' => $today_count ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-23 08:41:27 +08:00
}
/**
2020-09-24 19:09:05 +08:00
* 订单收入总计 , 今日 , 昨日 , 当月 , 上月总数
2019-02-23 08:41:27 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function OrderCompleteMoneyYesterdayTodayTotal ( $params = [])
{
// 初始化
self :: Init ( $params );
// 订单状态
// ( 0待确认, 1已确认/待支付, 2已支付/待发货, 3已发货/待收货, 4已完成, 5已取消, 6已关闭)
2021-08-31 18:08:12 +08:00
// 是否有收入统计权限
if ( AdminIsPower ( 'index' , 'income' ))
{
// 上月
$where = [
[ 'status' , 'in' , [ 2 , 3 , 4 ]],
[ 'add_time' , '>=' , self :: $last_month_time_start ],
[ 'add_time' , '<=' , self :: $last_month_time_end ],
];
2023-03-28 12:13:54 +08:00
$last_month_count = Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'pay_price' ) - Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'refund_price' );
2020-09-24 19:09:05 +08:00
2021-08-31 18:08:12 +08:00
// 当月
$where = [
[ 'status' , 'in' , [ 2 , 3 , 4 ]],
[ 'add_time' , '>=' , self :: $this_month_time_start ],
[ 'add_time' , '<=' , self :: $this_month_time_end ],
];
2023-03-28 12:13:54 +08:00
$same_month_count = Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'pay_price' ) - Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'refund_price' );
2020-09-24 19:09:05 +08:00
2021-08-31 18:08:12 +08:00
// 昨天
$where = [
[ 'status' , 'in' , [ 2 , 3 , 4 ]],
[ 'add_time' , '>=' , self :: $yesterday_time_start ],
[ 'add_time' , '<=' , self :: $yesterday_time_end ],
];
2023-03-28 12:13:54 +08:00
$yesterday_count = Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'pay_price' ) - Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'refund_price' );
2019-02-23 08:41:27 +08:00
2021-08-31 18:08:12 +08:00
// 今天
$where = [
[ 'status' , 'in' , [ 2 , 3 , 4 ]],
[ 'add_time' , '>=' , self :: $today_time_start ],
[ 'add_time' , '<=' , self :: $today_time_end ],
];
2023-03-28 12:13:54 +08:00
$today_count = Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'pay_price' ) - Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'refund_price' );
2021-08-31 18:08:12 +08:00
} else {
$last_month_count = 0.00 ;
$same_month_count = 0.00 ;
$yesterday_count = 0.00 ;
$today_count = 0.00 ;
}
2019-02-23 08:41:27 +08:00
// 数据组装
$result = [
2020-09-24 19:09:05 +08:00
'last_month_count' => PriceNumberFormat ( $last_month_count ),
'same_month_count' => PriceNumberFormat ( $same_month_count ),
2019-02-23 08:41:27 +08:00
'yesterday_count' => PriceNumberFormat ( $yesterday_count ),
'today_count' => PriceNumberFormat ( $today_count ),
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-23 08:41:27 +08:00
}
2020-08-15 12:05:18 +08:00
/**
2021-08-31 16:06:01 +08:00
* 基础数据总计
* @ author Devil
* @ blog http :// gong . gg /
* @ version 1.0 . 0
* @ date 2021 - 08 - 31
* @ desc description
* @ param [ array ] $params [ 输入参数 ]
*/
public static function BaseTotalCount ( $params = [])
{
// 日期条件处理
$where = [];
if ( ! empty ( $params [ 'start' ]))
{
$where [] = [ 'add_time' , '>=' , $params [ 'start' ]];
}
if ( ! empty ( $params [ 'end' ]))
{
$where [] = [ 'add_time' , '<=' , $params [ 'end' ]];
}
// 用户总数
$user_count = Db :: name ( 'User' ) -> where ( $where ) -> count ();
// 订单总数
$order_count = Db :: name ( 'Order' ) -> where ( array_merge ( $where , [[ 'status' , '<=' , 4 ]])) -> count ();
// 订单成交总量
$order_sale_count = Db :: name ( 'Order' ) -> where ( array_merge ( $where , [[ 'status' , '=' , 4 ]])) -> count ();
2021-08-31 18:08:12 +08:00
// 订单收入总计、是否有收入统计权限
if ( AdminIsPower ( 'index' , 'income' ))
{
2023-03-28 12:13:54 +08:00
$order_complete_total = Db :: name ( 'Order' ) -> where ( array_merge ( $where , [[ 'status' , 'in' , [ 2 , 3 , 4 ]]])) -> sum ( 'pay_price' ) - Db :: name ( 'Order' ) -> where ( array_merge ( $where , [[ 'status' , 'in' , [ 2 , 3 , 4 ]]])) -> sum ( 'refund_price' );
2021-08-31 18:08:12 +08:00
} else {
$order_complete_total = 0.00 ;
}
2021-08-31 16:06:01 +08:00
$result = [
'user_count' => $user_count ,
'order_count' => $order_count ,
'order_sale_count' => $order_sale_count ,
2021-08-31 18:08:12 +08:00
'order_complete_total' => PriceNumberFormat ( $order_complete_total ),
2021-08-31 16:06:01 +08:00
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2021-08-31 16:06:01 +08:00
}
/**
* 区间时间创建
* @ author Devil
* @ blog http :// gong . gg /
* @ version 1.0 . 0
* @ date 2021 - 08 - 30
* @ desc description
* @ param [ int ] $start [ 起始时间 ]
* @ param [ int ] $end [ 结束时间 ]
*/
public static function DayCreate ( $start , $end )
{
$data = [];
while ( true )
{
// 计算时间条件
$temp_end = strtotime ( '+1 day' , $start );
// 最大时间减1秒, 条件使用 start >= ? && end <= ?
// start 2021-01-01 00:00:00 , end 2021-01-01 23:59:58
$data [] = [
'start' => $start ,
'end' => $temp_end - 1 ,
'date' => date ( 'Y-m-d H:i:s' , $start ) . ' - ' . date ( 'Y-m-d H:i:s' , $temp_end - 1 ),
];
// 结束跳出循环
if ( $temp_end >= $end )
{
// 结束使用最大时间替代计算的最后一个最大时间
$count = count ( $data ) - 1 ;
$data [ $count ][ 'end' ] = $end ;
$data [ $count ][ 'date' ] = date ( 'Y-m-d H:i:s' , $data [ $count ][ 'start' ]) . ' - ' . date ( 'Y-m-d H:i:s' , $end );
break ;
}
$start = $temp_end ;
}
return $data ;
}
/**
2021-09-01 15:29:43 +08:00
* 订单交易趋势
2020-08-15 12:05:18 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
2021-09-01 15:29:43 +08:00
public static function OrderTradingTotal ( $params = [])
2020-08-15 12:05:18 +08:00
{
// 订单状态列表
2023-08-27 16:59:15 +08:00
$order_status_list = MyConst ( 'common_order_status' );
2020-08-15 12:05:18 +08:00
$status_arr = array_column ( $order_status_list , 'id' );
// 循环获取统计数据
$data = [];
$value_arr = [];
$name_arr = [];
2022-08-11 11:34:02 +08:00
$date = self :: DayCreate ( $params [ 'start' ], $params [ 'end' ]);
foreach ( $date as $day )
2020-08-15 12:05:18 +08:00
{
2022-08-11 11:34:02 +08:00
// 当前日期名称
$name_arr [] = date ( 'Y-m-d' , $day [ 'start' ]);
2020-08-15 12:05:18 +08:00
2022-08-11 11:34:02 +08:00
// 根据状态获取数量
foreach ( $status_arr as $status )
{
// 获取订单
$where = [
[ 'status' , '=' , $status ],
[ 'add_time' , '>=' , $day [ 'start' ]],
[ 'add_time' , '<=' , $day [ 'end' ]],
];
$value_arr [ $status ][] = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
2020-08-15 12:05:18 +08:00
}
}
// 数据格式组装
foreach ( $status_arr as $status )
{
$data [] = [
'name' => $order_status_list [ $status ][ 'name' ],
2021-09-01 15:29:43 +08:00
'type' => ( $status == 4 ) ? 'bar' : 'line' ,
2023-02-11 17:01:04 +08:00
'tiled' => MyLang ( 'common_service.statistical.stats_total_name' ),
2020-08-15 12:05:18 +08:00
'data' => empty ( $value_arr [ $status ]) ? [] : $value_arr [ $status ],
];
}
// 数据组装
$result = [
'title_arr' => array_column ( $order_status_list , 'name' ),
'name_arr' => $name_arr ,
'data' => $data ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2020-08-15 12:05:18 +08:00
}
2019-02-23 08:41:27 +08:00
/**
2021-09-01 15:29:43 +08:00
* 订单收益趋势
2019-02-23 08:41:27 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
2021-09-01 15:29:43 +08:00
public static function OrderProfitTotal ( $params = [])
2019-02-23 08:41:27 +08:00
{
// 订单状态列表
2023-08-27 16:59:15 +08:00
$order_status_list = MyConst ( 'common_order_status' );
2019-02-23 08:41:27 +08:00
$status_arr = array_column ( $order_status_list , 'id' );
// 循环获取统计数据
$data = [];
2020-08-15 12:05:18 +08:00
$value_arr = [];
2019-02-23 08:41:27 +08:00
$name_arr = [];
2021-09-02 09:28:42 +08:00
// 订单收入总计、是否有收入统计权限
if ( AdminIsPower ( 'index' , 'income' ))
2019-02-23 08:41:27 +08:00
{
2022-08-11 11:34:02 +08:00
$date = self :: DayCreate ( $params [ 'start' ], $params [ 'end' ]);
foreach ( $date as $day )
2019-02-23 08:41:27 +08:00
{
2022-08-11 11:34:02 +08:00
// 当前日期名称
$name_arr [] = date ( 'Y-m-d' , $day [ 'start' ]);
// 根据状态获取数量
foreach ( $status_arr as $status )
2019-02-23 08:41:27 +08:00
{
2022-08-11 11:34:02 +08:00
// 获取订单
$where = [
[ 'status' , '=' , $status ],
[ 'add_time' , '>=' , $day [ 'start' ]],
[ 'add_time' , '<=' , $day [ 'end' ]],
];
$value_arr [ $status ][] = Db :: name ( 'Order' ) -> where ( $where ) -> sum ( 'pay_price' );
2019-02-23 08:41:27 +08:00
}
}
2021-09-02 09:28:42 +08:00
// 数据格式组装
foreach ( $status_arr as $status )
{
$data [] = [
'name' => $order_status_list [ $status ][ 'name' ],
'type' => ( $status == 4 ) ? 'line' : 'bar' ,
2023-02-11 17:01:04 +08:00
'tiled' => MyLang ( 'common_service.statistical.stats_total_name' ),
2021-09-02 09:28:42 +08:00
'data' => empty ( $value_arr [ $status ]) ? [] : $value_arr [ $status ],
];
}
2019-02-23 08:41:27 +08:00
}
// 数据组装
$result = [
'title_arr' => array_column ( $order_status_list , 'name' ),
'name_arr' => $name_arr ,
'data' => $data ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-23 08:41:27 +08:00
}
2021-09-01 14:21:42 +08:00
/**
* 热销商品
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function GoodsHotTotal ( $params = [])
{
// 获取订单id
$where = [
[ 'status' , '<=' , 4 ],
];
if ( ! empty ( $params [ 'start' ]))
{
$where [] = [ 'add_time' , '>=' , $params [ 'start' ]];
}
if ( ! empty ( $params [ 'end' ]))
{
$where [] = [ 'add_time' , '<=' , $params [ 'end' ]];
}
$order_ids = Db :: name ( 'Order' ) -> where ( $where ) -> column ( 'id' );
// 获取订单详情热销商品
if ( empty ( $order_ids ))
{
$data = [];
} else {
2024-01-20 21:31:09 +08:00
$data = Db :: name ( 'OrderDetail' ) -> field ( 'goods_id, sum(buy_number) AS value' ) -> where ( 'order_id' , 'IN' , $order_ids ) -> group ( 'goods_id' ) -> order ( 'value desc' ) -> limit ( 13 ) -> select () -> toArray ();
2021-09-01 14:21:42 +08:00
}
if ( ! empty ( $data ))
{
foreach ( $data as & $v )
{
2022-03-05 20:31:15 +08:00
// 获取商品名称(这里不一次性读取、为了兼容 mysql 5.7+版本)
$v [ 'name' ] = Db :: name ( 'OrderDetail' ) -> where ( 'goods_id' , $v [ 'goods_id' ]) -> value ( 'title' );
2021-09-01 14:21:42 +08:00
if ( mb_strlen ( $v [ 'name' ], 'utf-8' ) > 12 )
{
$v [ 'name' ] = mb_substr ( $v [ 'name' ], 0 , 12 , 'utf-8' ) . '...' ;
}
unset ( $v [ 'goods_id' ]);
}
}
// 数据组装
$result = [
'name_arr' => array_column ( $data , 'name' ),
'data' => $data ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2021-09-01 14:21:42 +08:00
}
2019-02-23 08:41:27 +08:00
/**
2021-08-31 16:06:01 +08:00
* 支付方式
2019-02-23 08:41:27 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
2021-08-31 16:06:01 +08:00
public static function PayTypeTotal ( $params = [])
2019-02-23 08:41:27 +08:00
{
// 获取支付方式名称
$where = [
2020-09-08 23:36:30 +08:00
[ 'business_type' , '<>' , '' ],
[ 'status' , '=' , 1 ],
2019-02-23 08:41:27 +08:00
];
$pay_name_arr = Db :: name ( 'PayLog' ) -> where ( $where ) -> group ( 'payment_name' ) -> column ( 'payment_name' );
// 循环获取统计数据
$data = [];
2020-08-15 12:05:18 +08:00
$value_arr = [];
2019-02-23 08:41:27 +08:00
$name_arr = [];
if ( ! empty ( $pay_name_arr ))
{
2021-08-31 16:06:01 +08:00
$date = self :: DayCreate ( $params [ 'start' ], $params [ 'end' ]);
foreach ( $date as $day )
2019-02-23 08:41:27 +08:00
{
// 当前日期名称
2021-08-31 16:06:01 +08:00
$name_arr [] = date ( 'm-d' , $day [ 'start' ]);
2019-02-23 08:41:27 +08:00
// 根据支付名称获取数量
foreach ( $pay_name_arr as $payment )
{
// 获取订单
$where = [
[ 'payment_name' , '=' , $payment ],
2021-08-31 16:06:01 +08:00
[ 'add_time' , '>=' , $day [ 'start' ]],
[ 'add_time' , '<=' , $day [ 'end' ]],
2019-02-23 08:41:27 +08:00
];
2020-08-15 12:05:18 +08:00
$value_arr [ $payment ][] = Db :: name ( 'PayLog' ) -> where ( $where ) -> count ();
2019-02-23 08:41:27 +08:00
}
}
}
// 数据格式组装
foreach ( $pay_name_arr as $payment )
{
$data [] = [
'name' => $payment ,
'type' => 'line' ,
2023-02-11 17:01:04 +08:00
'stack' => MyLang ( 'common_service.statistical.stats_total_name' ),
2019-02-23 08:41:27 +08:00
'areaStyle' => ( object ) [],
2020-08-15 12:05:18 +08:00
'data' => empty ( $value_arr [ $payment ]) ? [] : $value_arr [ $payment ],
2019-02-23 08:41:27 +08:00
];
}
// 数据组装
$result = [
'title_arr' => $pay_name_arr ,
'name_arr' => $name_arr ,
'data' => $data ,
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-23 08:41:27 +08:00
}
/**
2021-09-01 14:21:42 +08:00
* 订单地域分布
2019-02-23 08:41:27 +08:00
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
2021-09-01 14:21:42 +08:00
public static function OrderWholeCountryTotal ( $params = [])
{
2021-09-01 15:29:43 +08:00
// 维度默认省
$region_arr = [ 'province_name' , 'city_name' , 'county_name' ];
2024-01-19 14:49:32 +08:00
$region_name = ( empty ( $params [ 'value' ]) || ! array_key_exists ( $params [ 'value' ], $region_arr )) ? 'od.' . $region_arr [ 0 ] : 'od.' . $region_arr [ $params [ 'value' ]];
2021-09-01 15:29:43 +08:00
2019-03-01 18:29:05 +08:00
// 获取订单id
2019-02-23 08:41:27 +08:00
$where = [
2024-01-19 14:49:32 +08:00
[ 'o.status' , '<=' , 4 ],
[ 'o.order_model' , 'not in' , [ 5 , 6 ]],
2019-02-23 08:41:27 +08:00
];
2021-08-31 18:08:12 +08:00
if ( ! empty ( $params [ 'start' ]))
{
2024-01-19 14:49:32 +08:00
$where [] = [ 'o.add_time' , '>=' , $params [ 'start' ]];
2021-08-31 18:08:12 +08:00
}
if ( ! empty ( $params [ 'end' ]))
{
2024-01-19 14:49:32 +08:00
$where [] = [ 'o.add_time' , '<=' , $params [ 'end' ]];
2021-08-31 18:08:12 +08:00
}
2024-01-19 14:49:32 +08:00
$data = array_reverse ( Db :: name ( 'Order' ) -> alias ( 'o' ) -> join ( 'order_address od' , 'o.id=od.order_id' ) -> where ( $where ) -> field ( $region_name . ' as name, count(o.id) AS value' ) -> group ( $region_name ) -> order ( 'value desc' ) -> limit ( 10 ) -> select () -> toArray ());
// 数据组装
$result = [
'name_arr' => array_column ( $data , 'name' ),
'data' => array_column ( $data , 'value' ),
];
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
}
2019-03-01 18:29:05 +08:00
2024-01-19 14:49:32 +08:00
/**
* 新增用户
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function NewUserTotal ( $params = [])
{
// 循环获取统计数据
$data = [];
$value_arr = [];
$name_arr = [];
$date = self :: DayCreate ( $params [ 'start' ], $params [ 'end' ]);
foreach ( $date as $day )
2019-03-01 18:29:05 +08:00
{
2024-01-19 14:49:32 +08:00
// 当前日期名称
$name_arr [] = date ( 'm-d' , $day [ 'start' ]);
// 用户总数
$where = [
[ 'add_time' , '>=' , $day [ 'start' ]],
[ 'add_time' , '<=' , $day [ 'end' ]],
];
$value_arr [] = Db :: name ( 'User' ) -> where ( $where ) -> count ();
2019-02-23 08:41:27 +08:00
}
2024-01-19 14:49:32 +08:00
// 数据格式组装
$data [] = [
'name' => MyLang ( 'common_service.statistical.stats_total_name' ),
'type' => 'line' ,
'data' => $value_arr ,
];
2019-02-23 08:41:27 +08:00
// 数据组装
$result = [
2024-01-19 14:49:32 +08:00
'name_arr' => $name_arr ,
'data' => $data ,
];
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
}
/**
* 下单用户
* @ author Devil
* @ blog http :// gong . gg /
* @ version 0.0 . 1
* @ datetime 2016 - 12 - 06 T21 : 31 : 53 + 0800
* @ param [ array ] $params [ 输入参数 ]
*/
public static function BuyUserTotal ( $params = [])
{
// 循环获取统计数据
$data = [];
$value_arr = [];
$name_arr = [];
$date = self :: DayCreate ( $params [ 'start' ], $params [ 'end' ]);
foreach ( $date as $day )
{
// 当前日期名称
$name_arr [] = date ( 'm-d' , $day [ 'start' ]);
// 用户总数
$where = [
[ 'add_time' , '>=' , $day [ 'start' ]],
[ 'add_time' , '<=' , $day [ 'end' ]],
[ 'status' , 'not in' , [ 5 , 6 ]],
];
$value_arr [] = Db :: name ( 'Order' ) -> where ( $where ) -> count ();
}
// 数据格式组装
$data [] = [
'name' => MyLang ( 'common_service.statistical.stats_total_name' ),
'type' => 'line' ,
'data' => $value_arr ,
];
// 数据组装
$result = [
'name_arr' => $name_arr ,
'data' => $data ,
2019-02-23 08:41:27 +08:00
];
2023-01-19 17:44:03 +08:00
return DataReturn ( MyLang ( 'handle_success' ), 0 , $result );
2019-02-22 18:38:11 +08:00
}
2021-08-31 16:06:01 +08:00
/**
* 统计数据
* @ author Devil
* @ blog http :// gong . gg /
* @ version 1.0 . 0
* @ date 2021 - 08 - 30
* @ desc description
* @ param [ array ] $params [ 输入参数 ]
*/
public static function StatsData ( $params = [])
{
// 请求类型
$p = [
[
'checked_type' => 'empty' ,
'key_name' => 'type' ,
2023-02-11 17:01:04 +08:00
'error_msg' => MyLang ( 'common_service.statistical.stats_type_empty_tips' ),
2021-08-31 16:06:01 +08:00
],
2021-08-31 18:08:12 +08:00
];
if ( isset ( $params [ 'type' ]) && in_array ( $params [ 'type' ], [ 'order-profit' , 'order-trading' , 'pay-type' ]))
{
$p [] = [
2021-08-31 16:06:01 +08:00
'checked_type' => 'empty' ,
'key_name' => 'start' ,
2023-02-11 17:01:04 +08:00
'error_msg' => MyLang ( 'common_service.statistical.stats_time_start_tips' ),
2021-08-31 18:08:12 +08:00
];
$p [] = [
2021-08-31 16:06:01 +08:00
'checked_type' => 'empty' ,
'key_name' => 'end' ,
2023-02-11 17:01:04 +08:00
'error_msg' => MyLang ( 'common_service.statistical.stats_time_end_tips' ),
2021-08-31 18:08:12 +08:00
];
}
2021-08-31 16:06:01 +08:00
$ret = ParamsChecked ( $params , $p );
if ( $ret !== true )
{
return DataReturn ( $ret , - 1 );
}
// 时间处理
2024-12-25 17:35:54 +08:00
if ( ! empty ( $params [ 'start' ]))
{
$params [ 'start' ] = strtotime ( $params [ 'start' ]);
}
if ( ! empty ( $params [ 'end' ]))
{
$params [ 'end' ] = strtotime ( $params [ 'end' ]);
}
if ( ! empty ( $params [ 'start' ]) && ! empty ( $params [ 'end' ]) && $params [ 'end' ] < $params [ 'start' ])
2021-08-31 16:06:01 +08:00
{
2023-02-11 17:01:04 +08:00
return DataReturn ( MyLang ( 'common_service.statistical.stats_time_error_tips' ), - 1 );
2021-08-31 16:06:01 +08:00
}
// 根据类型处理数据
switch ( $params [ 'type' ])
{
2024-10-21 10:51:14 +08:00
// 全部
case 'all' :
$order_profit = self :: OrderProfitTotal ( $params );
$order_trading = self :: OrderTradingTotal ( $params );
$goods_hot = self :: GoodsHotTotal ( $params );
$pay_type = self :: PayTypeTotal ( $params );
$order_whole_country = self :: OrderWholeCountryTotal ( $params );
$buy_user = self :: BuyUserTotal ( $params );
2024-12-26 01:05:57 +08:00
$new_user = self :: NewUserTotal ( $params );
2024-10-21 10:51:14 +08:00
$ret = DataReturn ( 'success' , 0 , [
'order_profit' => $order_profit [ 'data' ],
'order_trading' => $order_trading [ 'data' ],
'goods_hot' => $goods_hot [ 'data' ],
'pay_type' => $pay_type [ 'data' ],
'order_whole_country' => $order_whole_country [ 'data' ],
'buy_user' => $buy_user [ 'data' ],
2024-12-26 01:05:57 +08:00
'new_user' => $new_user [ 'data' ],
2024-10-21 10:51:14 +08:00
]);
break ;
2021-08-31 16:06:01 +08:00
// 基础配置
case 'base-count' :
$ret = self :: BaseTotalCount ( $params );
break ;
// 订单成交金额走势
case 'order-profit' :
$ret = self :: OrderProfitTotal ( $params );
break ;
// 订单交易走势
case 'order-trading' :
$ret = self :: OrderTradingTotal ( $params );
break ;
// 热销商品
case 'goods-hot' :
$ret = self :: GoodsHotTotal ( $params );
break ;
// 支付方式
case 'pay-type' :
$ret = self :: PayTypeTotal ( $params );
break ;
2021-09-01 14:21:42 +08:00
// 订单地域分布
case 'order-whole-country' :
2021-09-02 09:33:33 +08:00
$ret = self :: OrderWholeCountryTotal ( $params );
2021-09-01 14:21:42 +08:00
break ;
2024-01-19 14:49:32 +08:00
// 新增用户
case 'new-user' :
$ret = self :: NewUserTotal ( $params );
break ;
// 下单用户
case 'buy-user' :
$ret = self :: BuyUserTotal ( $params );
break ;
2021-08-31 16:06:01 +08:00
default :
2023-02-11 17:01:04 +08:00
$ret = DataReturn ( MyLang ( 'common_service.statistical.stats_type_error_tips' ), - 1 );
2021-08-31 16:06:01 +08:00
}
return $ret ;
}
2019-02-22 18:38:11 +08:00
}
?>