利用时间维度统计分页

简介: 在进行数据统计的时候,不能简单的通过数据表数据条数进行分页。这时,可以通过时间维度进行分页。 //以时间作为查询条件进行用户统计查询 $start_date = request('date')['start'] ? : ''; $end_date = request('date')['end'].

在进行数据统计的时候,不能简单的通过数据表数据条数进行分页。这时,可以通过时间维度进行分页。

//以时间作为查询条件进行用户统计查询

$start_date = request('date')['start'] ? : '';
$end_date = request('date')['end'] ? : '';

//以时间维度降序排列

//分页的最后一条数据时间
if ($start_date) {
    $start_at = $start_date;
} else {
    //$min_date 查询录入用户表里最早一个用户的日期(这里使用的时间戳)
    $start_at = $min_date ? date('Y-m-d', strtotime($min_date)) : date('Y-m-d', time());
}

//分页的第一条数据时间
if ($end_date) {
    $end_at = $end_date;
} else {
    $end_at = date('Y-m-d', time());
}

//计算第一条数据和最后一条数据两个时间的天数差
$days = (strtotime($end_at) - strtotime($start_at)) / (24 * 60 * 60) + 1;

//分页
$page = request('page') ?: 1;//页码
$per_page = request('per_page') ?: 15;//每页显示的条数

$max_page = ceil($days / $per_page);//最大页数

//页码不在合理范围,返回原页面
if ($page <= 0 || $page > $max_page) {
    return back();
}

//每页循环开始数字
$per_start = ($page - 1) * $per_page + 1;
//每页循环结束数字
$per_end = $page * $per_page;
$per_end = ($per_end < $days) ? $per_end : $days;

$lists = [];
for ($i = $per_start - 1; $i < $per_end; $i++) {
    $date = date('Y-m-d', strtotime("{$end_at} -{$i} days"));
    //根据当天时间,作为查询条件,查询业务模型数据,将数据返回结果追加到 $lists 数组里
    ...
}

//最后将 $lists 返回到页面展示
目录
相关文章
|
SQL 监控 数据挖掘
网站流量日志分析--统计分析--多维统计分析--时间维度--每小时指标统计|学习笔记
快速学习网站流量日志分析--统计分析--多维统计分析--时间维度--每小时指标统计
251 0
网站流量日志分析--统计分析--多维统计分析--时间维度--每小时指标统计|学习笔记
7-19 树种统计 (10 分)
7-19 树种统计 (10 分)
85 0
Excel 技术篇-跨页签统计某一区域下符合条件值的数量方法,COUNTIF函数、数量统计公式的用法实例演示
Excel 技术篇-跨页签统计某一区域下符合条件值的数量方法,COUNTIF函数、数量统计公式的用法实例演示
276 0
Excel 技术篇-跨页签统计某一区域下符合条件值的数量方法,COUNTIF函数、数量统计公式的用法实例演示
|
安全 供应链 容器
看板数量的计算
看板数量的计算   看板是丰田生产方式实现准时化的工具,从手段-目的链的角度来说,准时化是目的,看板是手段。看板用来实现领取物料和生产订单传递的工具,物料配送员和生产人员按照看板进行领料和生产。
1276 0
|
编解码 搜索推荐 内存技术
网站统计指标定义
(一)流量统计   1. 独立用户数:在当前计算周期内,访问统计对象的不重复用户数。万瑞数据系统通过对用户所使用的浏览器赋予唯一标识来识别用户的身份。同一浏览器在当前计算周期内多次访问同一统计对象时,该浏览器被计算为一个独立用户。
932 0