From 2e024c986c14943a41f7bfe913cfef0cede64198 Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期二, 29 七月 2025 17:37:54 +0800
Subject: [PATCH] 2025.7.29 1. 动态溯源模块添加记录删除等debug功能

---
 src/main/kotlin/com/flightfeather/uav/domain/repository/SatelliteGridRep.kt |   84 +++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 82 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 a8ae70e..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,6 +8,7 @@
 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
@@ -28,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 {
@@ -44,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 {
@@ -57,7 +97,27 @@
         return gridDataMapper.select(gridData)
     }
 
-    fun fetchGridDataDetail(dataId: Int, groupId: Int?, cellId: Int?): List<GridDataDetail?> {
+    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)
@@ -79,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?> {

--
Gitblit v1.9.3