审查视图

app/portal/model/StatisticsModel.php 1.7 KB
景龙 authored
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
<?php
/**
 * Author : xiaojie
 * DateTime: 2018/12/04 10:56
 */
namespace app\portal\model;

use think\Model;

class StatisticsModel extends Model
{

    /**
     * 计算总访问量
     * @return int|string
     */
    public function getTotalNum()
    {
        $num = $this->where('status',1)->count();
        return $num;
    }

    /**
     * 计算今日访问量
     * @return int|string
     */
    public function getTodayNum()
    {
        $num = $this->where([
            'status' => 1,
            'create_date' => date('Y-m-d')
        ])->count();
        return $num;
    }


    /**
     * 获取折线图数据
     * @return array
     */
    public function getBrokenData($map)
    {
        $list = $this
            ->field('address,count(address) as num')
            ->group('address')
            ->where($map)
            ->select()
            ->toArray();
       if(!empty($list)){
           foreach ($list as $k=>$v){
               $data['list1'][] =  $v['address'];
               $data['list2'][] =  $v['num'];
           }
           return $data;
       }
        return '';
    }

    /**
     * 获取饼形图数据
     * @return array
     */
    public function getCakeData($map)
    {
        $list = $this
            ->field('address,count(address) as num')
            ->group('address')
            ->where($map)
            ->select()
            ->toArray();
        if(!empty($list)){
            foreach ($list as $k=>$v){
                $list[$k][] = $v['address'];
                $list[$k][] = $v['num'];
                unset($list[$k]['address'],$list[$k]['num']);
            }
            return $list;
        }
        return '';
    }
}