专栏首页恩蓝脚本laravel实现按月或天或小时统计mysql数据的方法

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数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Android开发之缓冲dialog对话框创建、使用与封装操作

    本文实例讲述了Android开发之缓冲dialog对话框创建、使用与封装操作。分享给大家供大家参考,具体如下:

    砸漏
  • Python标准库json模块和pickle模块使用详解

    将Python数据类型转换为其他代码格式叫做(序列化),而json就是在各个代码实现转换的中间件。

    砸漏
  • PHP swoole中使用task进程异步的处理耗时任务应用案例分析

    本文实例讲述了PHP swoole中使用task进程异步的处理耗时任务。分享给大家供大家参考,具体如下:

    砸漏
  • 插入区间

    一份执着✘
  • LintCode 插入区间题目分析代码

    给出一个无重叠的按照区间起始端点排序的区间列表。 在列表中插入一个新的区间,你要确保列表中的区间仍然有序且不重叠 (如果有必要的话,可以合并区间)。

    desperate633
  • Rancher简介与安装

    仓库地址:https://hub.docker.com/r/rancher/server/ 官网:https://rancher.com/ docs:htt...

    菲宇
  • 递归反转字符串Java

    private static String f(String s, int end) {

    用户7886150
  • ruby学习笔记(4)-动态修改类的属性

    动态语言之所以“动态”,最明显的特征就是:类实例的行为/属性可以在new出后,动态修改!个人觉得这种处理相对java/c#(静态语言)来说,更符合现实世界。 ...

    菩提树下的杨过
  • 一天一大 leet(长度最小的子数组)难度:中等 DAY-28

    给定一个含有 n 个正整数的数组和一个正整数 s,找出该数组中满足其和 ≥s 的长度最小的连续子数组,并返回其长度。如果不存在符合条件的连续子数组,返回 0。

    前端小书童
  • Rancher技术剖析

    一,Rancher是什么 1.1 Rancher背景 ❶Rancher Labs成立于2014年。总部设立在美国加州的Cupertino。在美国的 亚利桑那州的...

    架构师小秘圈

扫码关注云+社区

领取腾讯云代金券