CarIllegalDownController.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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\Http\Request;
  6. use Illuminate\Routing\Controller;
  7. use Illuminate\Support\Facades\DB;
  8. class CarIllegalDownController extends BaseController
  9. {
  10. public function getList(Request $request) {
  11. $mineCode = isset($request->mine_code) ? $request->mine_code : null; // 矿分类
  12. $stateTime = isset($request->date) ? $request->date : date("Y-m-d"); // 统计日期
  13. $listStartTime = isset($request->date) ? $request->date.' 00:00:00' : date("Y-m-d 00:00:00"); // 开始时间
  14. $listEndTime = isset($request->date) ? $request->date.' 23:59:59' : date("Y-m-d 23:59:59"); // 结束时间
  15. $page = isset($request->page) ? $request->page : 0; // 分页
  16. $perPage = isset($request->perPage) ? $request->perPage : 20; // 每页显示几条
  17. // 超速违章统计
  18. for($i = 1; $i < 7; $i++) {
  19. // 今日
  20. $date = date("Y-m-d");
  21. $stime = sprintf("%02d",($i * 4 - 4)).":00:00";
  22. $etime = ($i * 4) == 24 ? "23:59:59":sprintf("%02d",($i * 4)).":00:00";
  23. $startTime = $date.' '.$stime;
  24. $endTime = $date.' '.$etime;
  25. $res = $this->getCarIllegalByTimeSpan($startTime, $endTime, $mineCode);
  26. $categories1[]= substr($etime, 0, -3);
  27. $data1[] = $res[0]->con;
  28. // 昨日
  29. $yesterday = date("Y-m-d", strtotime("-1 day"));
  30. $yStartTime = $yesterday.' '.$stime;
  31. $yEndTime = $yesterday.' '.$etime;
  32. $res = $this->getCarIllegalByTimeSpan($yStartTime, $yEndTime, $mineCode);
  33. $data2[] = $res[0]->con;
  34. }
  35. // 超速违章统计
  36. $res1 = [
  37. 'categories'=>$categories1,
  38. 'series'=>[
  39. [
  40. "name"=>"今日",
  41. "data"=> $data1
  42. ],
  43. [
  44. "name"=>"昨日",
  45. "data"=> $data2
  46. ],
  47. ],
  48. ];
  49. // 一周内超速趋势
  50. for($i = 1; $i < 7; $i++) {
  51. $stime = date("Y-m-d 00:00:00", strtotime("-".$i." day"));
  52. $etime = date("Y-m-d 23:59:59", strtotime("-".$i." day"));
  53. $res = $this->getCarIllegalByTimeSpan($stime, $etime, $mineCode);
  54. $categories3[]= date("m-d", strtotime("-".$i." day"));;
  55. $data3['data'][] = $res[0]->con;
  56. }
  57. $data3['name']="数量";
  58. $res2 = [
  59. 'categories'=>array_reverse($categories3),
  60. 'series'=>[array_reverse($data3)],
  61. ];
  62. // 违章数据列表
  63. $dataList = $this->getCarIllegalList($listStartTime, $listEndTime, $mineCode, $page, $perPage);
  64. $dataTotal = $this->getCarIllegalCount($stateTime, $mineCode);
  65. $data = [
  66. "total"=>$dataTotal,
  67. "speeding_con"=>$res1,
  68. "speeding_week"=>$res2,
  69. "detail_list"=>$dataList
  70. ];
  71. return json_encode($data);
  72. }
  73. // 今日超速统计
  74. public function getCarIllegalCount($stateDate, $mineCode='zaoquan') {
  75. $sqlStr = "select count(car_num) con from down_car_speed_warn where state_date = '{$stateDate}'";
  76. return $this->executeSql($sqlStr, 2, $mineCode);
  77. }
  78. // 超速详细列表
  79. public function getCarIllegalList($startTime, $endTime, $mineCode='zaoquan', $page=0, $perPage = 15) {
  80. $date = '2023-11-07';
  81. if ($startTime == null) return null;
  82. $sqlStr = 'SELECT b.numberplate, b.car_type, b.department, a.warn_start_time, a.warn_stop_time, a.act_val, a.warn_val ';
  83. $sqlStr .= 'FROM down_car_speed_warn a ';
  84. $sqlStr .= 'join down_car_base_info b on a.car_num = b.car_num ';
  85. $sqlStr .= 'where a.state_date = "'.$startTime.'"';
  86. $conn = 'etl_'.$mineCode;
  87. $dbResult = $this->executeSql($sqlStr, 4, $mineCode);
  88. for($i = 0; $i<count($dbResult); $i++) {
  89. $val = $dbResult[$i];
  90. $data[] = [
  91. 'car_number' => $val->numberplate,
  92. 'speed' => $val->act_val.'km/h',
  93. 'time' => $val->warn_start_time,
  94. 'place' => $val->department
  95. ];
  96. }
  97. return $data ?? null;
  98. }
  99. // 根据时段统计超速量
  100. public function getCarIllegalByTimeSpan($startTime, $endTime, $mineCode='zaoquan') {
  101. $sqlStr = /** @lang text */
  102. "select count(case when warn_start_time >= '{$startTime}'
  103. and warn_start_time < '{$endTime}' then car_num end) con
  104. from down_car_speed_warn where state_date = '".date("Y-m-d", strtotime($startTime))."'";
  105. // return $sqlStr;
  106. return $this->executeSql($sqlStr, 4, $mineCode);
  107. }
  108. public function executeSql($sqlStr, $modelname = -1, $mineCode='zaoquan') {
  109. $conn = 'etl_'.$mineCode;
  110. try{
  111. $opcDB = DB::connection($conn);
  112. $dbResult = $opcDB->select($sqlStr);
  113. return $dbResult;
  114. } catch (\Exception $e) {
  115. switch ($modelname) {
  116. case 1:
  117. return $this->error(-1, '统计超速数量出错!');
  118. case 2:
  119. return $this->error(-1, '统计日超速出错!');
  120. case 4:
  121. return $this->error(-1, '获取详细列表出错!');
  122. default:
  123. return $this->error(-1, '未知错误!');
  124. }
  125. }
  126. }
  127. }