laravel實(shí)現(xiàn)按月或天或小時(shí)統(tǒng)計(jì)mysql數(shù)據(jù)的方法
在PHP里怎么比較簡單的實(shí)現(xiàn)按時(shí)間(如按月,按天,按小時(shí))來統(tǒng)計(jì)表里的數(shù)據(jù)呢?
如:要實(shí)現(xiàn)獲取下圖曲線圖數(shù)據(jù)(ps:當(dāng)然也可能是柱狀圖等,數(shù)據(jù)都是一樣的),默認(rèn)獲取七天內(nèi)的數(shù)據(jù),點(diǎn)擊今天,7天,15天,30天可任意切換,其中今天是按小時(shí)統(tǒng)計(jì).
不過我的實(shí)現(xiàn)方法有一個小缺點(diǎn),當(dāng)某個小時(shí)內(nèi)是沒有數(shù)據(jù)的,那么該小時(shí)不會出現(xiàn),不過這個應(yīng)該可以通過前端的形式彌補(bǔ)
好了,廢話不多說,上圖上代碼!
1. 控制器內(nèi)容
/** * [getsellerdata 獲取某時(shí)間段內(nèi)商戶結(jié)算查詢數(shù)據(jù)] * @param Request $request [description] start:起始時(shí)間 end:結(jié)束時(shí)間 * @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 [起始時(shí)間]2017-08 * @param [string] $end [結(jié)束時(shí)間] * @return [type] [description] */ public function getSellerQuData($name,$start,$end){ //計(jì)算時(shí)間差值,以決定格式化時(shí)間格式 $diff = strtotime($end)-strtotime($start); //分組條件 1天內(nèi)按小時(shí)分組,否則按天/月分組 //86400/1天 2678400/1月 if($diff<86400&&$diff>0){ $sort = '%H'; }elseif($diff<2678400){ $sort = '%Y-%m-%d'; }else{ $sort = '%Y-%m'; } //把數(shù)據(jù)添加時(shí)間按格式化時(shí)間分組求和,求和分兩種,一種是直接求和,一種是滿足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}')")); //條件篩選 某時(shí)間段內(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實(shí)現(xiàn)按月或天或小時(shí)統(tǒng)計(jì)mysql數(shù)據(jù)的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- php、mysql查詢當(dāng)天,查詢本周,查詢本月的數(shù)據(jù)實(shí)例(字段是時(shí)間戳)
- mysql中獲取一天、一周、一月時(shí)間數(shù)據(jù)的各種sql語句寫法
- MySQL如何統(tǒng)計(jì)一個數(shù)據(jù)庫所有表的數(shù)據(jù)量
- mysql聚合統(tǒng)計(jì)數(shù)據(jù)查詢緩慢的優(yōu)化方法
- 詳解mysql 獲取某個時(shí)間段每一天、每一個小時(shí)的統(tǒng)計(jì)數(shù)據(jù)
- mysql按照天統(tǒng)計(jì)報(bào)表當(dāng)天沒有數(shù)據(jù)填0的實(shí)現(xiàn)代碼
- mysql 獲取規(guī)定時(shí)間段內(nèi)的統(tǒng)計(jì)數(shù)據(jù)
- MySql按時(shí),天,周,月進(jìn)行數(shù)據(jù)統(tǒng)計(jì)
相關(guān)文章
使用php發(fā)送有附件的電子郵件-(PHPMailer使用的實(shí)例分析)
本篇文章介紹了使用php發(fā)送有附件的電子郵件-(PHPMailer使用的實(shí)例分析)需要的朋友參考下2013-04-04Laravel5.1 框架分頁展示實(shí)現(xiàn)方法實(shí)例分析
這篇文章主要介紹了Laravel5.1 框架分頁展示實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了laravel5.1框架分頁展示邏輯功能實(shí)現(xiàn)與使用操作技巧,需要的朋友可以參考下2020-01-01自編函數(shù)解決pathinfo()函數(shù)處理中文問題
本文主要介紹了小編在使用pathinfo()函數(shù)處理中文文件名時(shí)遇到的一個小BUG的處理方式,有相同問題的童鞋們可以參考下2014-11-11PHP+jQuery+Ajax實(shí)現(xiàn)分頁效果 jPaginate插件的應(yīng)用
這篇文章主要介紹了PHP+jQuery+Ajax實(shí)現(xiàn)分頁效果,以及jPaginate插件的應(yīng)用2015-10-10PHP統(tǒng)計(jì)二維數(shù)組元素個數(shù)的方法
數(shù)據(jù)表里面的字段 content 存儲了一個以逗號分割的字符串,最大有20個數(shù),最大數(shù)字為40。比如3,24,33,40類似字樣的數(shù)字序列。其實(shí)就是一個保存了多項(xiàng)投票結(jié)果的字段啦?,F(xiàn)在需要統(tǒng)計(jì)每個數(shù)字的個數(shù),也就是每個投票項(xiàng)有多少人投了,并排序2013-11-11首頁四格,首頁五格For6.0(GBK)(UTF-8)[12種組合][9-18][版主安裝測試通過]
首頁四格,首頁五格For6.0(GBK)(UTF-8)[12種組合][9-18][版主安裝測試通過]...2007-09-09