query update
This commit is contained in:
		| @ -59,15 +59,15 @@ class ReportsController extends Controller | |||||||
| 		// $to_date = 1756745940; | 		// $to_date = 1756745940; | ||||||
|  |  | ||||||
| 		try { | 		try { | ||||||
| 			$list = DB::select("WITH trips AS ( | 			$list = DB::select("WITH  | ||||||
|  | 				gaps AS ( | ||||||
| 					SELECT | 					SELECT | ||||||
| 						t.*, | 						-- previous gap since previous row > 1 hour (3600s) | ||||||
| 						-- mark the start of a trip when ignition=4 and previous ignition <> 4 |  | ||||||
| 						CASE | 						CASE | ||||||
| 							WHEN ignition = 4  | 							WHEN (crt_d - LAG(crt_d, 1, NULL) OVER (PARTITION BY vhc_id ORDER BY crt_d)) > 3600 | ||||||
| 								AND LAG(ignition, 1, 0) OVER (PARTITION BY vhc_id ORDER BY crt_d) <> 4 |  | ||||||
| 							THEN 1 ELSE 0 | 							THEN 1 ELSE 0 | ||||||
| 						END AS trip_start | 						END AS isStop, | ||||||
|  | 						t.* | ||||||
| 					FROM t_gps_tracks t | 					FROM t_gps_tracks t | ||||||
| 					WHERE  | 					WHERE  | ||||||
| 					t.latitude IS NOT NULL | 					t.latitude IS NOT NULL | ||||||
| @ -75,13 +75,27 @@ class ReportsController extends Controller | |||||||
| 					AND t.action = 'location' | 					AND t.action = 'location' | ||||||
| 					AND t.crt_d BETWEEN ? AND ? | 					AND t.crt_d BETWEEN ? AND ? | ||||||
| 				) | 				) | ||||||
|  | 				, trips AS ( | ||||||
|  | 					SELECT | ||||||
|  | 						-- mark the start of a trip when ignition=4 and previous ignition <> 4 | ||||||
|  | 						CASE | ||||||
|  | 							WHEN ignition = 4  | ||||||
|  | 								AND LAG(ignition, 1, 0) OVER (PARTITION BY vhc_id ORDER BY crt_d) <> 4 | ||||||
|  | 								or LAG(isStop, 1, 0) over (PARTITION BY vhc_id ORDER BY crt_d) = 1 | ||||||
|  | 							THEN 1 ELSE 0 | ||||||
|  | 						END AS trip_start, | ||||||
|  | 						g.* | ||||||
|  | 					FROM gaps g | ||||||
|  | 				) | ||||||
| 				, numbered AS ( | 				, numbered AS ( | ||||||
| 					SELECT | 					SELECT | ||||||
| 						*, | 						*, | ||||||
| 						-- assign a trip_id by cumulative sum of trip_start | 						-- assign a trip_id by cumulative sum of trip_start | ||||||
| 						SUM(trip_start) OVER (PARTITION BY vhc_id ORDER BY crt_d) AS trip_id | 						SUM(trip_start) OVER (PARTITION BY vhc_id ORDER BY crt_d) AS trip_id | ||||||
| 					FROM trips | 					FROM trips | ||||||
| 					where ignition = 4 | 					where  | ||||||
|  | 						ignition = 4 | ||||||
|  | 						and isStop = 0 | ||||||
| 				), | 				), | ||||||
| 				agg AS ( | 				agg AS ( | ||||||
| 					SELECT | 					SELECT | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Pringgosutono
					Pringgosutono