From f1ea263462d1f3f10a886fb083536a38b03a1ceb Mon Sep 17 00:00:00 2001 From: feiyu02 <risaku@163.com> Date: 星期三, 14 五月 2025 17:33:04 +0800 Subject: [PATCH] 1. 新增动态污染溯源的数据异常判断逻辑 2. 新增动态污染溯源websocket连接功能 --- src/main/kotlin/com/flightfeather/uav/domain/repository/SatelliteGridRep.kt | 93 +++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 91 insertions(+), 2 deletions(-) diff --git a/src/main/kotlin/com/flightfeather/uav/domain/repository/SatelliteGridRep.kt b/src/main/kotlin/com/flightfeather/uav/domain/repository/SatelliteGridRep.kt index b88bc35..9233bcb 100644 --- a/src/main/kotlin/com/flightfeather/uav/domain/repository/SatelliteGridRep.kt +++ b/src/main/kotlin/com/flightfeather/uav/domain/repository/SatelliteGridRep.kt @@ -8,7 +8,9 @@ import com.flightfeather.uav.domain.mapper.GridDataMapper import com.flightfeather.uav.domain.mapper.GridGroupMapper import com.flightfeather.uav.lightshare.bean.AreaVo +import com.github.pagehelper.PageHelper import org.springframework.stereotype.Repository +import org.springframework.transaction.annotation.Transactional import tk.mybatis.mapper.entity.Example import java.time.LocalDateTime @@ -27,15 +29,48 @@ private val gridAodDetailMapper: GridAodDetailMapper, ) { - fun fetchGridGroup(areaVo: AreaVo): List<GridGroup?> { + fun fetchGridGroup(areaVo: AreaVo, type: String?): List<GridGroup?> { return gridGroupMapper.selectByExample(Example(GridGroup::class.java).apply { createCriteria() .andEqualTo("provinceCode", areaVo.provinceCode).andEqualTo("provinceName", areaVo.provinceName) .andEqualTo("cityCode", areaVo.cityCode).andEqualTo("cityName", areaVo.cityName) .andEqualTo("districtCode", areaVo.districtCode).andEqualTo("districtName", areaVo.districtName) .andEqualTo("townCode", areaVo.townCode).andEqualTo("townName", areaVo.townName) + .andEqualTo("type", type) }) } + + fun fetchGridGroup(id: Int): GridGroup? { + return gridGroupMapper.selectByPrimaryKey(id) + } + + fun fetchGridGroup(gridGroup: GridGroup): List<GridGroup?> { + return gridGroupMapper.select(gridGroup) + } + + fun insertGridGroup(gridGroup: GridGroup): Int { + return gridGroupMapper.insert(gridGroup) + } + + @Transactional + fun deleteGridGroup(groupId: Int) { + gridCellMapper.delete(GridCell().apply { this.groupId = groupId }) + PageHelper.startPage<GridCell>(1, 1) + gridCellMapper.selectByExample( + Example(GridCell::class.java).apply { orderBy("id").desc() } + ).takeIf { it.isNotEmpty() }?.get(0)?.id?.let { id -> + gridCellMapper.resetAutoIncrement(id + 1) + } + gridGroupMapper.deleteByPrimaryKey(groupId) + PageHelper.startPage<GridGroup>(1, 1) + gridGroupMapper.selectByExample( + Example(GridGroup::class.java).apply { orderBy("id").desc() } + ).takeIf { it.isNotEmpty() }?.get(0)?.id?.let { id -> + gridGroupMapper.resetAutoIncrement(id + 1) + } + } + + /*****************************************************************/ fun fetchGridCell(groupId: Int): List<GridCell?> { return gridCellMapper.selectByExample(Example(GridCell::class.java).apply { @@ -43,6 +78,12 @@ orderBy("id") }) } + + fun insertGridCell(gridCellList: List<GridCell?>): Int { + return gridCellMapper.insertList(gridCellList) + } + + /*****************************************************************/ fun fetchGridData(groupId: Int, dataTime: LocalDateTime?, type: Int?): List<GridData?> { return gridDataMapper.selectByExample(Example(GridData::class.java).apply { @@ -52,7 +93,31 @@ }) } - fun fetchGridDataDetail(dataId: Int, groupId: Int?, cellId: Int?): List<GridDataDetail?> { + fun fetchGridData(gridData: GridData): List<GridData?> { + return gridDataMapper.select(gridData) + } + + fun fetchGridData(id: Int): GridData? { + return gridDataMapper.selectByPrimaryKey(id) + } + + fun insertGridData(gridData: GridData): Int { + return gridDataMapper.insert(gridData) + } + + fun insertGridDataDetail(gridDataDetails: List<GridDataDetail?>): Int { + return gridDataDetailMapper.insertList(gridDataDetails) + } + + fun updateGridDataDetail(gridDataDetails: List<GridDataDetail?>): Int { + var res = 0 + gridDataDetails.forEach { + res += gridDataDetailMapper.updateByPrimaryKey(it) + } + return res + } + + fun fetchGridDataDetail(dataId: Int? = null, groupId: Int? = null, cellId: Int? = null): List<GridDataDetail?> { return gridDataDetailMapper.selectByExample(Example(GridDataDetail::class.java).apply { createCriteria().andEqualTo("dataId", dataId) .andEqualTo("groupId", groupId) @@ -74,6 +139,26 @@ gridDataDetailMapper.updatePM25Batch(gridDataDetails) } + @Transactional + @Throws + fun deleteGridData(dataId: Int?) { + gridDataDetailMapper.delete(GridDataDetail().apply { this.dataId = dataId }) + // Fixme 2025.4.16 姝ゅ鐨勯噸缃嚜澧瀒d鍙湪鍒犻櫎鏈�鏂版暟鎹殑鎯呭喌涓嬫湁鏁堬紝鍚庣画鑰冭檻涓嶉�傜敤鑷涓婚敭锛屾敼涓烘柊鐨勪富閿敓鎴愭柟寮� +// PageHelper.startPage<GridDataDetail>(1, 1) +// gridDataDetailMapper.selectByExample(Example(GridDataDetail::class.java).apply { orderBy("id").desc() }) +// .takeIf { it.isNotEmpty() }?.get(0)?.id?.let { id -> +// gridDataDetailMapper.resetAutoIncrement(id + 1) +// } + gridDataMapper.deleteByPrimaryKey(dataId) +// PageHelper.startPage<GridData>(1, 1) +// gridDataMapper.selectByExample( +// Example(GridData::class.java).apply { orderBy("id").desc() } +// ).takeIf { it.isNotEmpty() }?.get(0)?.id?.let { id -> +// gridDataMapper.resetAutoIncrement(id + 1) +// } + } + + /*****************************************************************/ // aod 鐩稿叧鎿嶄綔 fun fetchGridAod(groupId: Int, dataTime: LocalDateTime?): List<GridAod?> { @@ -109,7 +194,11 @@ .andEqualTo("cellId", it.cellId) }) } + } + @Transactional + fun updateGridCellBatch(gridCellList: List<GridCell?>) { + gridCellList.forEach { gridCellMapper.updateByPrimaryKey(it) } } } \ No newline at end of file -- Gitblit v1.9.3