areaCode = $this->request->param('areaCode', ''); $this->streetCode = $this->request->param('streetCode', ''); if ($this->areaCode == '') { throw new ValidateException('未获取到位置信息'); } } // 溯源产品统计 public function plantProductCount() { $list = LandPlant::alias('lp')->join('land l', 'l.id=lp.land_id')->field('lp.kind,lp.qr_code') ->where(function ($query) { if ($this->streetCode != '') { $query->where('l.town_code', $this->streetCode); } else { $query->where('l.county_code', $this->areaCode); } })->limit(30)->select(); return $this->success('成功', compact('list')); } // 智能预警数据 public function landCollectionList() { // 先排序,再分组 $subQuery = Db::name('land_collection') ->order('id', 'desc') ->limit(1000) ->buildSql(); $list = Db::table($subQuery)->alias('lc') ->field('lc.*,l.title') ->join('land l', 'l.id=lc.land_id') ->where(function ($query) { if ($this->streetCode != '') { $query->where('l.town_code', $this->streetCode); } else { $query->where('l.county_code', $this->areaCode); } })->order('lc.id', 'desc')->group('l.id')->limit(30)->select(); return $this->success('成功', compact('list')); } // 预警历史记录 public function landMonitorAlarmHistory() { $landId = $this->request->get('land_id'); $start = date('Y-m-d', time()); $end = date('Y-m-d', strtotime('-1 month')); $typeRow = ['soil_temperature', 'soil_moisture', 'soil_PH', 'soil_potassium_phosphate_nitrogen', 'wind_speed', 'ambient_temperature', 'ambient_humidity', 'carbon_dioxide']; $list = []; foreach ($typeRow as $type) { // 土壤磷酸钾-氮磷钾 if ($type == 'soil_potassium_phosphate_nitrogen') { $alarmCount = MonitorAlarm::where('land_id', $landId) ->whereIn('type', ['soil_potassium_phosphate_nitrogen', 'soil_potassium_phosphate_phosphorus', 'soil_potassium_phosphate_potassium']) ->whereBetweenTime('create_time', $start, $end) ->count(); $historyList = LandCollection::where('land_id', $landId)->field(['soil_potassium_phosphate_nitrogen', 'soil_potassium_phosphate_phosphorus', 'soil_potassium_phosphate_potassium'])->select(); } else { $alarmCount = MonitorAlarm::where('land_id', $landId) ->where('type', $type) ->whereBetweenTime('create_time', $start, $end) ->count(); $historyList = LandCollection::where('land_id', $landId)->field($type)->select(); } $list[] = compact('alarmCount', 'historyList'); } return $this->success('成功', compact('list')); } // 土地列表 public function landList() { $list = Land::where(function ($query) { if ($this->streetCode != '') { $query->where('l.town_code', $this->streetCode); } else { $query->where('l.county_code', $this->areaCode); } })->select(); } public function centralCount() { $query = Land::alias('l')->where(function ($query) { if ($this->streetCode != '') { $query->where('l.town_code', $this->streetCode); } else { $query->where('l.county_code', $this->areaCode); } }); // 地块数量 $landCount = $query->count(); // 种植面积 $totalArea = $query->sum('total_area'); // 种植种类 $plantCount = $query->join('land_plant lp', 'l.id = lp.land_id')->group('kind')->count(); return $this->success('成功', compact('landCount', 'totalArea', 'plantCount')); } }