CarIllegalController.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. <?php
  2. namespace Modules\OpcData\Http\Controllers\Api;
  3. use App\Http\Controllers\Api\BaseController;
  4. use Illuminate\Contracts\Support\Renderable;
  5. use Illuminate\Routing\Controller;
  6. use Illuminate\Support\Facades\DB;
  7. use Illuminate\Http\Request;
  8. class CarIllegalController extends BaseController
  9. {
  10. public function getList(Request $request) {
  11. $mineCode = isset($request->mine_code) ? $request->mine_code : null; // 矿分类
  12. $listStartTime = isset($request->date) ? $request->date.' 00:00:00' : date("Y-m-d 00:00:00"); // 开始时间
  13. $listEndTime = isset($request->date) ? $request->date.' 23:59:59' : date("Y-m-d 23:59:59"); // 结束时间
  14. $page = isset($request->page) ? $request->page : 0; // 分页
  15. $perPage = isset($request->perPage) ? $request->perPage : 20; // 每页显示几条
  16. // 超速违章统计
  17. for($i = 1; $i < 7; $i++) {
  18. // 今日
  19. $date = date("Y-m-d");
  20. $stime = sprintf("%02d",($i * 4 - 4)).":00:00";
  21. $etime = ($i * 4) == 24 ? "23:59:59":sprintf("%02d",($i * 4)).":00:00";
  22. $startTime = $date.' '.$stime;
  23. $endTime = $date.' '.$etime;
  24. $res = $this->getCarIllegalByTimeSpan($startTime, $endTime);
  25. $categories1[]= substr($etime, 0, -3);
  26. $data1[] = $res[0]->con;
  27. // 昨日
  28. $yesterday = date("Y-m-d", strtotime("-1 day"));
  29. $yStartTime = $yesterday.' '.$stime;
  30. $yEndTime = $yesterday.' '.$etime;
  31. $res = $this->getCarIllegalByTimeSpan($yStartTime, $yEndTime);
  32. $data2[] = $res[0]->con;
  33. }
  34. // 超速违章统计
  35. $res1 = [
  36. 'categories'=>$categories1,
  37. 'series'=>[
  38. [
  39. "name"=>"今日",
  40. "data"=> $data1
  41. ],
  42. [
  43. "name"=>"昨日",
  44. "data"=> $data2
  45. ],
  46. ],
  47. ];
  48. // 一周内超速趋势
  49. for($i = 1; $i < 7; $i++) {
  50. $stime = date("Y-m-d 00:00:00", strtotime("-".$i." day"));
  51. $etime = date("Y-m-d 23:59:59", strtotime("-".$i." day"));
  52. $res = $this->getCarIllegalByTimeSpan($stime, $etime);
  53. $categories3[]= date("m-d", strtotime("-".$i." day"));;
  54. $data3['data'][] = $res[0]->con;
  55. }
  56. $res2 = [
  57. 'categories'=>array_reverse($categories3),
  58. 'series'=>array_reverse($data3),
  59. ];
  60. // 违章数据列表
  61. $dataList = $this->getCarIllegalList($listStartTime, $listEndTime, $page, $perPage);
  62. $dataTotal = $this->getCarIllegalCount($mineCode);
  63. $data = [
  64. "total"=>$dataTotal[0]->total,
  65. "speeding_con"=>$res1,
  66. "speeding_week"=>$res2,
  67. "detail_list"=>$dataList
  68. ];
  69. return json_encode($data);
  70. }
  71. // 今日超速统计
  72. public function getCarIllegalCount($mineCode='zaoquan') {
  73. $sqlStr = "SELECT count(DISTINCT state_date, plate_number, DATE_FORMAT(illegal_time,'%Y-%m-%d %h'), point_name, illegal_speed, speed_limit) total ";
  74. $sqlStr .= "FROM cars_violation ";
  75. $sqlStr .= "WHERE DATE_FORMAT(illegal_time,'%Y-%m-%d') = curdate() ";
  76. $sqlStr .= "AND plate_number != '无车牌' ";
  77. $conn = 'etl_'.$mineCode;
  78. try {
  79. $opcDB = DB::connection($conn);
  80. $dbResult = $opcDB->select($sqlStr);
  81. return $dbResult;
  82. } catch (\Exception $e) {
  83. return $this->error(-1, '今日超速统计出错!');
  84. }
  85. }
  86. // 超速详细列表
  87. public function getCarIllegalList($startTime, $endTime, $mineCode='zaoquan', $page=0, $perPage = 15) {
  88. $sqlStr = "SELECT DISTINCT state_date, plate_number, substr(illegal_time, 1, 16 ) illegal_time, point_name, illegal_speed, speed_limit ";
  89. $sqlStr .= "FROM cars_violation ";
  90. $sqlStr .= "WHERE illegal_time >='".$startTime."' and illegal_time < '".$endTime."' ";
  91. $sqlStr .= "AND plate_number != '无车牌' ";
  92. $sqlStr .= "order by illegal_time desc ";
  93. // $sqlStr .= "limit ".$page.", ".$perPage."";
  94. // return $sqlStr;
  95. $conn = 'etl_zaoquan';
  96. try{
  97. $opcDB = DB::connection($conn);
  98. $dbResult = $opcDB->select($sqlStr);
  99. for($i = 0; $i<count($dbResult); $i++) {
  100. $val = $dbResult[$i];
  101. $data[] = [
  102. 'car_number' => $val->plate_number,
  103. 'speed' => $val->illegal_speed.'km/h',
  104. 'time' => $val->illegal_time,
  105. 'place' => $val->point_name
  106. ];
  107. }
  108. return $data;
  109. } catch (\Exception $e) {
  110. return $this->error(-1, '超速详细列表出错!');
  111. }
  112. }
  113. // 根据时段统计超速量
  114. public function getCarIllegalByTimeSpan($startTime, $endTime, $mineCode='zaoquan') {
  115. $sqlStr = "select count(case when illegal_time >= '".$startTime."' and illegal_time < '".$endTime."' then 1 end) con ";
  116. // $sqlStr .= "count(case when illegal_time >= '".$startTime."' and illegal_time < '".$endTime."' then 1 end) con_yestday ";
  117. $sqlStr .= "from ( SELECT distinct state_date, plate_number, substr(illegal_time, 1, 13) illegal_time, point_name, illegal_speed, speed_limit ";
  118. $sqlStr .= "from cars_violation where state_date ='".date("Y-m-d", strtotime($startTime))."' ";
  119. $sqlStr .= "and plate_number != '无车牌' ";
  120. $sqlStr .= ") t";
  121. // return $sqlStr;
  122. $conn = 'etl_zaoquan';
  123. try{
  124. $opcDB = DB::connection($conn);
  125. $dbResult = $opcDB->select($sqlStr);
  126. return $dbResult;
  127. } catch (\Exception $e) {
  128. return $this->error(-1, '根据时段统计超速量出错!');
  129. }
  130. }
  131. }