laravel实现按时间日期进行分组统计方法示例


Posted in PHP onMarch 23, 2019

按日期进行分组

//统计七天内注册用户数量按天进行分组
$user = DB::table('users')->whereBetween('created_at',['2018-01-01','2018-01-07'])
 ->selectRaw('date(created_at) as date,count(*) as value')
 ->groupBy('date')->get();

#获取的用户分组数据
{
 "date": "2018-01-01", #日期
 "value": 199  #数量
{
 "date": "2018-01-02",
 "value": 298
},
{
 "date": "2018-01-03",
 "value": 1000
}
 
#在进行图表统计的时候直接从数据库取得数据有些日期可能是没有的,就需要我们手动进行补全一些日期
#计算日期内天数
$stimestamp = strtotime($start_time);
$etimestamp = strtotime($end_time);
#计算日期段内有多少天
$days = ($etimestamp - $stimestamp) / 86400;
#保存每天日期
$date = array();
for($i = 0;$i < $days;$i++){
 $date[] = date('Y-m-d', $stimestamp + (86400 * $i));
}
#循环补全日期
foreach ($date as $key => $val){
 $data[$key] = [
 'date' => $val,
 'value' => 0
 ];
 foreach ($user as $item => $value){
 if($val == $value['date']){
  $data[$key] = $value;
 }
 }
}
return $data;

按月份进行分组

#统计一年内注册用户数量按月份进行分组
$user = DB::table('users')->whereBetween('created_at',['2018-01-01','2018-12-31'])
 ->selectRaw('DATE_FORMAT(created_at,"%Y-%m") as date,COUNT(*) as value')
 ->groupBy('date')->get();
#获取的用户分组数据
{
 "date": "2018-01", #月份
 "value": 1497  #数量
},
{
 "date": "2018-02",
 "value": 2354
},
{
 "date": "2018-03",
 "value": 4560
} 
#在进行图表统计的时候直接从数据库取得的数据有的月份可能是没有的,不过月份比较少可直接写死,同样也需要补全
$year = date('Y',time());
#一年的月份
$month = [
 0 => $year.'-01',
 1 => $year.'-02',
 2 => $year.'-03',
 3 => $year.'-04',
 4 => $year.'-05',
 5 => $year.'-06',
 6 => $year.'-07',
 7 => $year.'-08',
 8 => $year.'-09',
 9 => $year.'-10',
 10 => $year.'-11',
 11 => $year.'-12',
];
#循环补全月份
foreach ($month as $key => $val){
 $data[$key] = [
 'date' => $val,
 'value' => 0
 ];
 foreach ($user as $item => $value){
 if($val == $value['date']){
  $data[$key] = $value;
 }
 }
}
return $data;

laravel实现各时间段数量统计、方便直接使用

因项目中用到了图表之类的信息,需要获取到很多时间的数据动态,刚开始我都是自己换算时间来计算,后来 看到手册中有更简单的方法,自己总结了一下通用的时间段统计(今天、昨天、上周、本周、上月、本月、上年、本年)。

use Carbon\Carbon;
 
public function getNumber()
{
  $data = [];

  #今天数据
  $data['customer_today'] = Customer::where('customer_type', 1)->where('created_at', Carbon::today())->count();
  #昨天数据
  $data['customer_yesterday'] = Customer::where('customer_type', 1)->where('created_at', Carbon::yesterday())->count();

  // 本周数据
  $this_week = [Carbon::now()->startOfWeek(), Carbon::now()->endOfWeek()];
  $data['customer_this_week'] = Customer::where('customer_type', 1)->whereBetween('created_at', $this_week)->count();

  // 上周数据
  $last_week = [Carbon::now()->startOfWeek()->subWeek(), Carbon::now()->endOfWeek()->subWeek()];
  $data['customer_last_week'] = Customer::where('customer_type', 1)->whereBetween('created_at', $last_week)->count();

  // 本月数据
  $data['customer_this_month'] = Customer::where('customer_type', 1)->whereMonth('created_at', Carbon::now()->month)->count();

  // 上月数据
  $data['customer_last_month'] = Customer::where('customer_type', 1)->whereMonth('created_at', Carbon::now()->subMonth()->month)->count();

  // 本年数据
  $data['customer_this_year'] = Customer::where('customer_type', 1)->whereYear('created_at', Carbon::now()->year)->count();

  
  return $data;
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

PHP 相关文章推荐
PHP的中问验证码
Nov 25 PHP
php基础知识:类与对象(2) 自动加载对象
Dec 13 PHP
不错的一篇面向对象的PHP开发模式(简写版)
Mar 15 PHP
相对路径转化成绝对路径
Apr 10 PHP
深入探讨:PHP使用数据库永久连接方式操作MySQL的是与非
Jun 05 PHP
用Json实现PHP与JavaScript间数据交换的方法详解
Jun 20 PHP
ThinkPHP的L方法使用简介
Jun 18 PHP
使用array_map简单搞定PHP删除文件、删除目录
Oct 29 PHP
PHP中遇到的时区问题解决方法
Jul 23 PHP
thinkphp在低版本Nginx 下支持PATHINFO的方法分享
May 27 PHP
PHP面向对象程序设计之对象克隆clone和魔术方法__clone()用法分析
Jun 12 PHP
PHP递归统计系统中代码行数
Sep 19 PHP
PHP使用OB缓存实现静态化功能示例
Mar 23 #PHP
Laravel如何自定义command命令浅析
Mar 23 #PHP
PHP使用mysqli同时执行多条sql查询语句的实例
Mar 22 #PHP
PHP中命名空间的使用例子
Mar 22 #PHP
PHP SESSION机制的理解与实例
Mar 22 #PHP
PHP析构函数destruct与垃圾回收机制的讲解
Mar 22 #PHP
PHP中的empty、isset、isnull的区别与使用实例
Mar 22 #PHP
You might like
异世界新番又来了,同样是从零开始,男主的年龄降到5岁
2020/04/09 日漫
php中使用$_REQUEST需要注意的一个问题
2013/05/02 PHP
服务器变量 $_SERVER 的深入解析
2013/07/02 PHP
php多线程实现方法及用法实例详解
2015/10/26 PHP
php操作redis数据库常见方法实例总结
2020/02/20 PHP
js下通过prototype扩展实现indexOf的代码
2010/12/08 Javascript
ie支持function.bind()方法实现代码
2012/12/27 Javascript
JS JSON对象转为字符串的简单实现方法
2013/11/18 Javascript
node.js中的http.response.end方法使用说明
2014/12/14 Javascript
JS运动基础框架实例分析
2015/03/03 Javascript
原生js制作日历控件实例分享
2016/04/06 Javascript
Bootstrap每天必学之导航组件
2016/04/25 Javascript
解析Javascript单例模式概念与实例
2016/12/05 Javascript
js使用html2canvas实现屏幕截取的示例代码
2017/08/28 Javascript
JavaScript登录验证基础教程
2017/11/01 Javascript
react配合antd组件实现的管理系统示例代码
2018/04/24 Javascript
vuejs router history 配置到iis的方法
2018/09/20 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
2019/06/14 Javascript
基于element-ui对话框el-dialog初始化的校验问题解决
2020/09/11 Javascript
Python os模块中的isfile()和isdir()函数均返回false问题解决方法
2015/02/04 Python
numpy添加新的维度:newaxis的方法
2018/08/02 Python
Python matplotlib的使用并自定义colormap的方法
2018/12/13 Python
Python入门Anaconda和Pycharm的安装和配置详解
2019/07/16 Python
Python实现GIF图倒放
2020/07/16 Python
python爬虫调度器用法及实例代码
2020/11/30 Python
CSS3属性 line-clamp控制文本行数的使用
2020/03/19 HTML / CSS
The Hut德国站点:时装、家居用品、美容等
2016/09/23 全球购物
亚洲最大的眼镜批发商和零售商之一:Glasseslit
2018/10/08 全球购物
大学毕业感言50字
2014/02/07 职场文书
篮球比赛口号
2014/06/10 职场文书
乡镇平安建设汇报材料
2014/08/25 职场文书
尼克胡哲观后感
2015/06/08 职场文书
Python 如何安装Selenium
2021/05/06 Python
详解SpringBoot异常处理流程及原理
2021/06/21 Java/Android
使用logback实现按自己的需求打印日志到自定义的文件里
2021/08/30 Java/Android
Java实现HTML转为Word的示例代码
2022/06/28 Java/Android