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)商戶結算查詢數(shù)據(jù)]
* @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. 庫文件內(nèi)容
/**
* [getSellerQuData 獲取商戶結算數(shù)據(jù) 曲線]
* @param [string] $start [起始時間]2017-08
* @param [string] $end [結束時間]
* @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)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- php、mysql查詢當天,查詢本周,查詢本月的數(shù)據(jù)實例(字段是時間戳)
- mysql中獲取一天、一周、一月時間數(shù)據(jù)的各種sql語句寫法
- MySQL如何統(tǒng)計一個數(shù)據(jù)庫所有表的數(shù)據(jù)量
- mysql聚合統(tǒng)計數(shù)據(jù)查詢緩慢的優(yōu)化方法
- 詳解mysql 獲取某個時間段每一天、每一個小時的統(tǒng)計數(shù)據(jù)
- mysql按照天統(tǒng)計報表當天沒有數(shù)據(jù)填0的實現(xiàn)代碼
- mysql 獲取規(guī)定時間段內(nèi)的統(tǒng)計數(shù)據(jù)
- MySql按時,天,周,月進行數(shù)據(jù)統(tǒng)計
相關文章
PHP中使用GD庫繪制折線圖 折線統(tǒng)計圖的繪制方法
本文通過代碼給大家介紹php中使用GD庫繪制折線圖,涉及到php中GD庫的一些簡單使用,本文介紹的非常詳細,感興趣的朋友一起學習吧2015-11-11
Laravel5.7 數(shù)據(jù)庫操作遷移的實現(xiàn)方法
這篇文章主要介紹了 Laravel5.7 數(shù)據(jù)庫操作遷移的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04
thinkphp調(diào)用sqlserver儲存過程返回多個結果集
這篇文章主要介紹了thinkphp調(diào)用sqlserver儲存過程返回多個結果集,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01

