laravel实现按月或天或小时统计mysql数据的方法

 更新时间:2019年10月09日 16:14:03   作者:php_girl  
今天小编就为大家分享一篇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数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • PHP队列场景以及实现代码实例详解

    PHP队列场景以及实现代码实例详解

    这篇文章主要介绍了PHP队列场景以及实现代码实例详解,有感兴趣的同学可以跟着学习研究下
    2021-02-02
  • php多维数组去掉重复值示例分享

    php多维数组去掉重复值示例分享

    这篇文章主要介绍了php多维数组去掉重复值示例,需要的朋友可以参考下
    2014-03-03
  • Zend Framework教程之模型Model基本规则和使用方法

    Zend Framework教程之模型Model基本规则和使用方法

    这篇文章主要介绍了Zend Framework教程之模型Model基本规则和使用方法,结合实例形式详细分析了Zend Framework中模型的原理与具体使用技巧,需要的朋友可以参考下
    2016-03-03
  • Yii2框架制作RESTful风格的API快速入门教程

    Yii2框架制作RESTful风格的API快速入门教程

    Yii提供了一整套用来简化实现RESTful风格的WebService服务的API。这篇文章主要介绍了Yii2框架制作RESTful风格的API快速入门教程的相关资料,需要的朋友可以参考下
    2016-11-11
  • PHP将URL转换成短网址的算法分享

    PHP将URL转换成短网址的算法分享

    短网址(Short URL)顾名思义就是在形式上比较短的网址。在Web 2.0的今天,不得不说这是一个潮流。目前已经有许多类似服务,借助短网址您可以用简短的网址替代原来冗长的网址,让使用者可以更容易的分享链接,下面来看看如何用PHP实现这个功能,有需要的朋友们可以参考。
    2016-09-09
  • 基于curl数据采集之单页面采集函数get_html的使用

    基于curl数据采集之单页面采集函数get_html的使用

    在做数据采集时经常要使用到curl+正则的方式采集需要的数据 根据自己的工作经验 把自己写的一些常用自定义函数 与大家来分享 如果有写得不恰当的地方 请多多指教
    2013-04-04
  • php读取der格式证书乱码解决方法

    php读取der格式证书乱码解决方法

    这篇文章主要介绍了php读取der格式证书乱码解决方法的相关资料,需要的朋友可以参考下
    2015-06-06
  • PHP模板引擎Smarty自定义变量调解器用法

    PHP模板引擎Smarty自定义变量调解器用法

    这篇文章主要介绍了PHP模板引擎Smarty自定义变量调解器用法,较为详细的分析了smarty变量调节器的用法与自定义变量调节器的实现技巧,需要的朋友可以参考下
    2016-04-04
  • PHP如何实现跨域

    PHP如何实现跨域

    这篇文章主要介绍了PHP如何实现跨域的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2016-05-05
  • Redis使用Eval多个键值自增的操作实例

    Redis使用Eval多个键值自增的操作实例

    下面小编就为大家带来一篇Redis使用Eval 多个键值自增的操作实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11

最新评论