laravel实现按月或天或小时统计mysql数据的方法
时间:2022-07-27
本文章向大家介绍laravel实现按月或天或小时统计mysql数据的方法,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
在PHP里怎么比较简单的实现按时间(如按月,按天,按小时)来统计表里的数据呢?
如:要实现获取下图曲线图数据(ps:当然也可能是柱状图等,数据都是一样的),默认获取七天内的数据,点击今天,7天,15天,30天可任意切换,其中今天是按小时统计.
不过我的实现方法有一个小缺点,当某个小时内是没有数据的,那么该小时不会出现,不过这个应该可以通过前端的形式弥补
好了,废话不多说,上图上代码!
1. 控制器内容
/**
* [getsellerdata 获取某时间段内商户结算查询数据]
* @param Request $request [description] start:起始时间 end:结束时间
* @return [type] [description]
*/
public function getsellerqudata(Request $request){
$data = $this- dataanalysis- getSellerQuData($request- start,$request- end);
return $data;
}
2. 库文件内容
/**
* [getSellerQuData 获取商户结算数据 曲线]
* @param [string] $start [起始时间]2017-08
* @param [string] $end [结束时间]
* @return [type] [description]
*/
public function getSellerQuData($name,$start,$end){
//计算时间差值,以决定格式化时间格式
$diff = strtotime($end)-strtotime($start);
//分组条件 1天内按小时分组,否则按天/月分组
//86400/1天 2678400/1月
if($diff<86400&&$diff 0){
$sort = '%H';
}elseif($diff<2678400){
$sort = '%Y-%m-%d';
}else{
$sort = '%Y-%m';
}
//把数据添加时间按格式化时间分组求和,求和分两种,一种是直接求和,一种是满足case when条件的数据求和
$query = DB::table('user_withdrawals as w')- select(DB::raw("FROM_UNIXTIME(created_at,'{$sort}') as thedata,sum(case when w.cash_type = 1 then w.money end) as xiabi,sum(case when w.cash_type = 2 then w.money end) as online,sum(w.money) as alls"))- groupBy(DB::raw("FROM_UNIXTIME(created_at,'{$sort}')"));
//条件筛选 某时间段内
if( !empty($start) ){
$query- whereRaw('w.created_at = ?',strtotime($start));
}
if( !empty($end) ){
$query- whereRaw('w.created_at <= ?',strtotime($end));
}
$data = $query- get();
return $data;
}
以上这篇laravel实现按月或天或小时统计mysql数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考。
- dom4j的读写xml文件,读写xml字符串
- 省市县三级联动
- 从国家统计局爬下来的地区信息
- app令牌的一个token实现
- velocity分页模板
- js基础-表单验证和提交
- No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
- oracle创建用户
- oracle创建表相关
- spring学习遇到的问题汇总
- Java XML解析工具 dom4j介绍及使用实例
- redis学习教程之一基本命令
- 在java中使用redis
- springmvc学习笔记--json--返回json的日期格式问题
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- 6.深入k8s:守护进程DaemonSet及源码分析
- 无所不能的Embedding 1 - Word2vec模型详解&代码实现
- 【JS】676- 1.1w字 | 初中级前端 JavaScript 自测清单 - 2
- matplotlib基础绘图命令之imshow
- 聊聊dubbo-go的broadcastCluster
- 爬取博客园文章
- 配置Python开发环境
- 部署Python应用
- 重写ThreadPoolTaskExecutor
- 聊聊dubbo-go的forkingCluster
- 创建多线程的4种方式
- 线程通讯wait¬ify
- 最新深度学习框架——OneFlow:新分布式训练(附源代码)
- 多线程相关概念
- MySQL安装教程