[英]laravel join with only limiting 2 row
所以我有這種查詢,我像這樣用最大日期/時間段進行分組
$table_data = App\salesreport::join(DB::RAW('(SELECT company_id, MAX(period) AS max_period FROM salesreport GROUP BY company_id ) latest_report'),function($join){
$join->on('salesreport.company_id','=','latest_report.company_id');
$join->on('salesreport.periods','=','latest_report.max_periods');
})->get()
它工作得很好,它可以將所有公司歸為一個,然后只顯示最新的一個MAX(period)
。 然后我想對其進行更多調整,如果我不僅要展示最新的,還要展示每家公司的最新兩個怎么樣? 所以每家公司將返回所有報告中最新的 2 份報告。
然后我想也許添加LIMIT 2
會使它起作用所以我這樣說
$table_data = App\salesreport::join(DB::RAW('(SELECT company_id, MAX(period) AS max_period FROM salesreport GROUP BY company_id ) latest_report'),function($join){
$join->on('salesreport.company_id','=','latest_report.company_id');
$join->on('salesreport.periods','<=','latest_report.max_periods');
$join->limit(2)
})->get()
但它沒有效果,只顯示所有周期 <= max_periods 的公司的所有報告。
為了讓事情更清楚這里是我加入的表
這是我的銷售報告表
+----+------------+-------+------------+
| id | company_id | price | periods |
+----+------------+-------+------------+
| 1 | A1 | 500 | 2016-07-12 |
| 2 | A2 | 540 | 2017-01-21 |
| 3 | A1 | 440 | 2017-01-19 |
| 4 | A1 | 440 | 2018-01-19 |
| 5 | A2 | 330 | 2016-01-12 |
| 6 | A2 | 333 | 2018-01-22 |
+----+------------+-------+------------+
然后在那里使用第一個查詢然后我會得到這種表
+----+------------+-------+------------+
| id | company_id | price | periods |
+----+------------+-------+------------+
| 4 | A1 | 440 | 2018-01-19 |
| 6 | A2 | 333 | 2018-01-22 |
+----+------------+-------+------------+
所以我想要的是得到這種桌子
+----+------------+-------+------------+
| id | company_id | price | periods |
+----+------------+-------+------------+
| 4 | A1 | 440 | 2018-01-19 |
| 3 | A1 | 440 | 2017-01-19 |
| 6 | A2 | 333 | 2018-01-22 |
| 2 | A2 | 540 | 2017-01-21 |
+----+------------+-------+------------+
所以每家公司的最新 2 個.. 有可能嗎? 只有一個請求?
使用這個技巧:
App\salesreport::join(DB::RAW('(SELECT company_id, GROUP_CONCAT(periods ORDER BY periods DESC) grouped_periods FROM salesreport GROUP BY company_id ) latest_report'),function($join){
$join->on('salesreport.company_id','=','latest_report.company_id');
$join->whereBetween(DB::raw('FIND_IN_SET(`salesreport`.`periods`, `latest_report`.`grouped_periods`)'), [1, 2]);
})->get();
使用這個技巧:
App\salesreport::join(DB::RAW('(SELECT company_id, GROUP_CONCAT(periods ORDER BY periods DESC) grouped_periods FROM salesreport GROUP BY company_id ) latest_report'),function($join){
$join->on('salesreport.company_id','=','latest_report.company_id');
$join->whereBetween(DB::raw('FIND_IN_SET(`salesreport`.`periods`, `latest_report`.`grouped_periods`)'), [1, 2]);
})->get();
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.