亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

laravel實現(xiàn)按月或天或小時統(tǒng)計mysql數(shù)據(jù)的方法

 更新時間:2019年10月09日 16:14:03   作者:php_girl  
今天小編就為大家分享一篇laravel實現(xiàn)按月或天或小時統(tǒng)計mysql數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在PHP里怎么比較簡單的實現(xiàn)按時間(如按月,按天,按小時)來統(tǒng)計表里的數(shù)據(jù)呢?

如:要實現(xiàn)獲取下圖曲線圖數(shù)據(jù)(ps:當然也可能是柱狀圖等,數(shù)據(jù)都是一樣的),默認獲取七天內(nèi)的數(shù)據(jù),點擊今天,7天,15天,30天可任意切換,其中今天是按小時統(tǒng)計.

不過我的實現(xiàn)方法有一個小缺點,當某個小時內(nèi)是沒有數(shù)據(jù)的,那么該小時不會出現(xiàn),不過這個應該可以通過前端的形式彌補

好了,廢話不多說,上圖上代碼!

1. 控制器內(nèi)容

  /**
   * [getsellerdata 獲取某時間段內(nèi)商戶結(jié)算查詢數(shù)據(jù)]
   * @param Request $request [description] start:起始時間 end:結(jié)束時間 
   * @return [type]      [description]
   */
  public function getsellerqudata(Request $request){
    $data = $this->dataanalysis->getSellerQuData($request->start,$request->end);
    return $data;    
  }

2. 庫文件內(nèi)容

 /**
   * [getSellerQuData 獲取商戶結(jié)算數(shù)據(jù) 曲線]
   * @param [string] $start [起始時間]2017-08
   * @param [string] $end  [結(jié)束時間]
   * @return [type]    [description]
   */
  public function getSellerQuData($name,$start,$end){

    //計算時間差值,以決定格式化時間格式
    $diff = strtotime($end)-strtotime($start);

    //分組條件 1天內(nèi)按小時分組,否則按天/月分組
    //86400/1天 2678400/1月
    if($diff<86400&&$diff>0){
      $sort = '%H';
    }elseif($diff<2678400){
      $sort = '%Y-%m-%d';
    }else{
      $sort = '%Y-%m';
    }
    //把數(shù)據(jù)添加時間按格式化時間分組求和,求和分兩種,一種是直接求和,一種是滿足case when條件的數(shù)據(jù)求和
    $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}')"));

    //條件篩選 某時間段內(nèi)
    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實現(xiàn)按月或天或小時統(tǒng)計mysql數(shù)據(jù)的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

最新評論