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数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持澳门金沙网上娱乐。

相关文章

  • CI框架常用函数封装实例

    CI框架常用函数封装实例

    这篇文章主要介绍了CI框架常用函数封装,结合实例形式分析了CI框架常用的金沙国际官网查询、插入、删除、更新及debug调试等操作技巧,需要的朋友可以参考下
    2016-11-11
  • 基于laravel Request的所有方法详解

    基于laravel Request的所有方法详解

    今天小编就为大家分享一篇基于laravel Request的所有方法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • 解决phpcms更换javascript的幻灯片代码调用图片问题

    解决phpcms更换javascript的幻灯片代码调用图片问题

    这篇文章主要介绍了解决phpcms更换javascript的幻灯片代码调用图片问题,需要的朋友可以参考下
    2014-12-12
  • Centos PHP 扩展Xchche的安装教程

    Centos PHP 扩展Xchche的安装教程

    这篇文章主要介绍了Centos PHP 扩展Xchche的安装教程的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • PHP中Session引起的脚本阻塞问题解决办法

    PHP中Session引起的脚本阻塞问题解决办法

    这个问题很多做php开发朋友应该都有遇到过,一个启用了session_start 页面,由于执行时间过长。导致通一个用户访问,另外一个很简单的启用session_start页面一直阻塞着。 直到第一个页面执行完了。第二个页面才可以读取。这个就是,我们常说的session阻塞机制。
    2014-04-04
  • php制作圆形用户头像的实例_自定义封装类源代码

    php制作圆形用户头像的实例_自定义封装类源代码

    下面小编就为大家带来一篇php制作圆形用户头像的实例_自定义封装类源代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • Ajax PHP JavaScript MySQL实现简易无刷新在线聊天室

    Ajax PHP JavaScript MySQL实现简易无刷新在线聊天室

    这篇文章主要介绍了Ajax PHP JavaScript MySQL实现简易无刷新在线聊天室,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • PHP面向对象之事务脚本模式(详解)

    PHP面向对象之事务脚本模式(详解)

    下面小编就为大家带来一篇PHP面向对象之事务脚本模式(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Symfony核心类概述

    Symfony核心类概述

    这篇文章主要介绍了Symfony核心类,简单分析了Symfony的核心类,组织结构及对应的功能,需要的朋友可以参考下
    2016-03-03
  • yii2.0整合阿里云oss删除单个文件的方法

    yii2.0整合阿里云oss删除单个文件的方法

    这篇文章主要介绍了yii2.0整合阿里云oss删除单个文件的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09

最新评论