From 42922f126d7259f8a1da6a81d5ee8e9e45300278 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期五, 22 十一月 2024 15:23:22 +0800
Subject: [PATCH] 设计实现导出当前升级任务成功与失败RTU功能

---
 pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java  |  149 ++++++++-------------
 pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeSv.java    |   57 ++++----
 pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voUg/VoUgRtuResult.java                        |   30 ++++
 pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeResSv.java |  160 ++++++++++++++++++++++
 4 files changed, 275 insertions(+), 121 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voUg/VoUgRtuResult.java b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voUg/VoUgRtuResult.java
new file mode 100644
index 0000000..2653252
--- /dev/null
+++ b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voUg/VoUgRtuResult.java
@@ -0,0 +1,30 @@
+package com.dy.pipIrrGlobal.voUg;
+
+import com.alibaba.excel.annotation.ExcelProperty;
+import com.alibaba.excel.annotation.write.style.ColumnWidth;
+import com.alibaba.excel.annotation.write.style.ContentRowHeight;
+import com.alibaba.excel.annotation.write.style.ContentStyle;
+import com.alibaba.excel.annotation.write.style.HeadRowHeight;
+import com.alibaba.excel.enums.poi.HorizontalAlignmentEnum;
+import com.alibaba.excel.enums.poi.VerticalAlignmentEnum;
+import lombok.Data;
+
+/**
+ * @Author: liurunyu
+ * @Date: 2024/11/22 14:26
+ * @Description
+ */
+@Data
+@HeadRowHeight(26)
+@ContentRowHeight(22)
+public class VoUgRtuResult {
+    @ExcelProperty("鎺у埗鍣ㄥ湴鍧�")
+    @ColumnWidth(20)
+    @ContentStyle(horizontalAlignment = HorizontalAlignmentEnum.CENTER, verticalAlignment = VerticalAlignmentEnum.CENTER)
+    public String rtuAddr;
+
+    @ExcelProperty("鍗囩骇缁撴灉")
+    @ColumnWidth(30)
+    @ContentStyle(horizontalAlignment = HorizontalAlignmentEnum.LEFT, verticalAlignment = VerticalAlignmentEnum.CENTER)
+    public String result;
+}
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
index 0e99c5e..ec86f88 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
@@ -1,7 +1,8 @@
 package com.dy.pipIrrRemote.rtuUpgrage;
 
+import com.alibaba.excel.EasyExcel;
+import com.alibaba.excel.support.ExcelTypeEnum;
 import com.dy.common.aop.SsoAop;
-import com.dy.common.multiDataSource.DataSourceContext;
 import com.dy.common.softUpgrade.state.UpgradeRtu;
 import com.dy.common.softUpgrade.state.UpgradeTaskVo;
 import com.dy.common.springUtil.SpringContextUtil;
@@ -12,6 +13,8 @@
 import com.dy.pipIrrGlobal.pojoUg.UgRtuProgram;
 import com.dy.pipIrrGlobal.pojoUg.UgRtuTask;
 import com.dy.pipIrrGlobal.rtuMw.ToRtuMwCom;
+import com.dy.pipIrrGlobal.voPr.VoDivide;
+import com.dy.pipIrrGlobal.voUg.VoUgRtuResult;
 import com.dy.pipIrrGlobal.voUg.VoWatch;
 import io.swagger.v3.oas.annotations.Operation;
 import io.swagger.v3.oas.annotations.media.Content;
@@ -19,15 +22,19 @@
 import io.swagger.v3.oas.annotations.responses.ApiResponse;
 import io.swagger.v3.oas.annotations.responses.ApiResponses;
 import io.swagger.v3.oas.annotations.tags.Tag;
+import jakarta.servlet.http.HttpServletResponse;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.core.env.Environment;
 import org.springframework.http.MediaType;
 import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
 import org.springframework.web.bind.annotation.RestController;
 import org.springframework.web.client.RestTemplate;
 
+import java.io.UnsupportedEncodingException;
+import java.net.URLEncoder;
 import java.util.ArrayList;
 import java.util.Base64;
 import java.util.List;
@@ -44,6 +51,9 @@
 public class RtuUpgradeCtrl extends ToRtuMwCom {
     @Autowired
     private RtuUpgradeSv sv ;
+
+    @Autowired
+    RtuUpgradeResSv resSv ;
 
     @Autowired
     private Environment env;
@@ -128,9 +138,10 @@
         vo.softBytesCalculate = ppo.programCalculateBytes ;
         vo.softByteSrc16 = ppo.programCrc16 ;
     }
+
+
     /**
-     *  鐩戣锛�
-     * 閲嶇疆锛屾紨绀虹殑閲嶇疆
+     * 閲嶇疆杩滅▼鍗囩骇婕旂ず绋嬪簭
      * @return 鎿嶄綔缁撴灉
      */
     @GetMapping(path = "/demoReset")
@@ -166,7 +177,7 @@
         if(qvo == null){
             qvo = new QueryVo();
             qvo.pageCurr = 1 ;
-            qvo.pageSize = 50 ;
+            qvo.pageSize = 49 ;
         }
         if(RtuUpgradeStateReceiverCtrl.cache == null){
             //return BaseResponseUtils.buildError("褰撳墠娌℃湁鍗囩骇浠诲姟") ;
@@ -174,96 +185,50 @@
             RtuUpgradeStateReceiverCtrl ctrl = SpringContextUtil.getBean(RtuUpgradeStateReceiverCtrl.class);
             ctrl.demo();
         }
-
-        QueryResultVo<VoWatch> rsVo = new QueryResultVo();
-        VoWatch vo = new VoWatch() ;
-        List<UpgradeRtu> listFiltered = null ;
-        if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){
-            vo.upgrade = this.sv.selectTaskDetail(RtuUpgradeStateReceiverCtrl.cache.ugTaskId);
-            vo.overall = RtuUpgradeStateReceiverCtrl.cache.ugOverallState ;
-            vo.rtus = new ArrayList<>() ;
-            if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) {
-                listFiltered = filterByQuery(qvo) ;
-                if (listFiltered.size() > 0) {
-                    if(qvo.pageCurr < 1){
-                        qvo.pageCurr = 1 ;
-                    }
-                    int start = (qvo.pageCurr - 1) * qvo.pageSize ;
-                    if(start >= listFiltered.size()){
-                        if(listFiltered.size()%qvo.pageSize > 0){
-                            start = listFiltered.size() - listFiltered.size()%qvo.pageSize ;
-                        }else{
-                            start = listFiltered.size() - qvo.pageSize ;
-                        }
-                    }
-                    for(int i = start; i < (start + qvo.pageSize) && i < listFiltered.size(); i++){
-                        UpgradeRtu ugRtu = listFiltered.get(i) ;
-                        VoWatch.VoWatchRtu rtu = new VoWatch.VoWatchRtu() ;
-                        rtu.fromCache(ugRtu) ;
-                        vo.rtus.add(rtu) ;
-                    }
-                }
-            }
-        }
-
-        rsVo.obj = vo ;
-        rsVo.pageSize = qvo.pageSize ;
-        rsVo.pageCurr = qvo.pageCurr ;
-        rsVo.calculateAndSet(0L + (listFiltered==null?0:listFiltered.size()), null);
+        QueryResultVo<VoWatch> rsVo = this.resSv.curUpgradeState(qvo) ;
         return BaseResponseUtils.buildSuccess(rsVo) ;
     }
 
-    private List<UpgradeRtu> filterByQuery(QueryVo qvo){
-        if (qvo.status != null || qvo.result != null) {
-            final Integer qvoStatus = qvo.status ;
-            final Integer qvoResult = qvo.result ;
-            final String qvoRtuAddr = qvo.rtuAddr ;
-            return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.stream().filter(rtu -> {
-                boolean ok = false;
-                if (qvoStatus != null) {
-                    if (qvoStatus.intValue() == 1) {
-                        if (rtu.state == UpgradeRtu.STATE_RUNNING) {
-                            ok = true;
-                        }else{
-                            ok = false ;
-                        }
-                    } else if (qvoStatus.intValue() == 0) {
-                        if (rtu.isOver) {
-                            ok = true;
-                        }else{
-                            ok = false ;
-                        }
-                    }
-                }
-                if (qvoResult != null) {
-                    if (qvoResult.intValue() == 1) {
-                        if (rtu.state == UpgradeRtu.STATE_SUCCESS) {
-                            ok = true;
-                        }else{
-                            ok = false ;
-                        }
-                    } else if (qvoResult.intValue() == 0) {
-                        if (rtu.state == UpgradeRtu.STATE_OFFLINE
-                                || rtu.state == UpgradeRtu.STATE_FAILONE
-                                || rtu.state == UpgradeRtu.STATE_FAIL
-                                || rtu.state == UpgradeRtu.STATE_FAILOFFLINE) {
-                            ok = true;
-                        }else{
-                            ok = false ;
-                        }
-                    }
-                }
-                if(qvoRtuAddr != null && !qvoRtuAddr.trim().equals("")){
-                    if(rtu.rtuAddr.equals(qvoRtuAddr)){
-                        ok = true;
-                    }else{
-                        ok = false ;
-                    }
-                }
-                return ok;
-            }).toList() ;
-        }else{
-            return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList ;
-        }
+    /**
+     * 瀵煎嚭鍗囩骇澶辫触RTU鍒楄〃
+     * @param response
+     */
+    @RequestMapping(value = "/exportUgFail", method = RequestMethod.GET)
+    public void exportUgFail(HttpServletResponse response) throws Exception {
+        setExcelRespProp(response, "鍗囩骇澶辫触RTU鍒楄〃");
+        List<VoUgRtuResult> rsList = resSv.exportUgFail();
+        EasyExcel.write(response.getOutputStream())
+                .head(VoUgRtuResult.class)
+                .excelType(ExcelTypeEnum.XLSX)
+                .sheet("鍗囩骇澶辫触RTU鍒楄〃")
+                .doWrite(rsList);
     }
+
+
+    /**
+     * 瀵煎嚭闀跨骇鎴愬姛RTU鍒楄〃
+     * @param response
+     */
+    @RequestMapping(value = "/exportUgSuccess", method = RequestMethod.GET)
+    public void exportUgSuccess(HttpServletResponse response) throws Exception {
+        setExcelRespProp(response, "鍗囩骇鎴愬姛RTU鍒楄〃");
+        List<VoUgRtuResult> rsList = resSv.exportUgSuccess();
+        EasyExcel.write(response.getOutputStream())
+                .head(VoUgRtuResult.class)
+                .excelType(ExcelTypeEnum.XLSX)
+                .sheet("鍗囩骇鎴愬姛RTU鍒楄〃")
+                .doWrite(rsList);
+    }
+
+
+    /**
+     * 璁剧疆excel涓嬭浇鍝嶅簲澶村睘鎬�
+     */
+    private void setExcelRespProp(HttpServletResponse response, String rawFileName) throws UnsupportedEncodingException {
+        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
+        response.setCharacterEncoding("utf-8");
+        String fileName = URLEncoder.encode(rawFileName, "UTF-8").replaceAll("\\+", "%20");
+        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
+    }
+
 }
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeResSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeResSv.java
new file mode 100644
index 0000000..03c204d
--- /dev/null
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeResSv.java
@@ -0,0 +1,160 @@
+package com.dy.pipIrrRemote.rtuUpgrage;
+
+import com.dy.common.softUpgrade.state.UpgradeRtu;
+import com.dy.common.webUtil.QueryResultVo;
+import com.dy.pipIrrGlobal.voUg.VoUgRtuResult;
+import com.dy.pipIrrGlobal.voUg.VoWatch;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * @Author liurunyu
+ * @Date 2024/11/22 14:40
+ * @Description
+ */
+@Slf4j
+@Service
+public class RtuUpgradeResSv {
+    @Autowired
+    private RtuUpgradeSv sv ;
+
+    public QueryResultVo<VoWatch> curUpgradeState(QueryVo qvo){
+        QueryResultVo<VoWatch> rsVo = new QueryResultVo<>();
+        VoWatch vo = new VoWatch() ;
+        List<UpgradeRtu> listFiltered = null ;
+        if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){
+            vo.upgrade = this.sv.selectTaskDetail(RtuUpgradeStateReceiverCtrl.cache.ugTaskId);
+            vo.overall = RtuUpgradeStateReceiverCtrl.cache.ugOverallState ;
+            vo.rtus = new ArrayList<>() ;
+            if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) {
+                listFiltered = filterByQuery(qvo) ;
+                if (listFiltered.size() > 0) {
+                    if(qvo.pageCurr < 1){
+                        qvo.pageCurr = 1 ;
+                    }
+                    int start = (qvo.pageCurr - 1) * qvo.pageSize ;
+                    if(start >= listFiltered.size()){
+                        if(listFiltered.size()%qvo.pageSize > 0){
+                            start = listFiltered.size() - listFiltered.size()%qvo.pageSize ;
+                        }else{
+                            start = listFiltered.size() - qvo.pageSize ;
+                        }
+                    }
+                    for(int i = start; i < (start + qvo.pageSize) && i < listFiltered.size(); i++){
+                        UpgradeRtu ugRtu = listFiltered.get(i) ;
+                        VoWatch.VoWatchRtu rtu = new VoWatch.VoWatchRtu() ;
+                        rtu.fromCache(ugRtu) ;
+                        vo.rtus.add(rtu) ;
+                    }
+                }
+            }
+        }
+
+        rsVo.obj = vo ;
+        rsVo.pageSize = qvo.pageSize ;
+        rsVo.pageCurr = qvo.pageCurr ;
+        rsVo.calculateAndSet((long)(listFiltered==null?0:listFiltered.size()), null);
+        return rsVo ;
+    }
+
+    /**
+     * 杩囨护缁撴灉
+     * @param qvo 鏌ヨ鍙傛暟
+     * @return 闆嗗悎
+     */
+    private List<UpgradeRtu> filterByQuery(QueryVo qvo){
+        if (qvo.status != null || qvo.result != null) {
+            Integer qvoStatus = qvo.status ;
+            Integer qvoResult = qvo.result ;
+            String qvoRtuAddr = qvo.rtuAddr ;
+            return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.stream().filter(rtu -> {
+                boolean ok = false;
+                if (qvoStatus != null) {
+                    if (qvoStatus == 1) {
+                        ok = rtu.state == UpgradeRtu.STATE_RUNNING;
+                    } else if (qvoStatus == 0) {
+                        ok = rtu.isOver;
+                    }
+                }
+                if (qvoResult != null) {
+                    if (qvoResult == 1) {
+                        ok = rtu.state == UpgradeRtu.STATE_SUCCESS;
+                    } else if (qvoResult == 0) {
+                        ok = rtu.state == UpgradeRtu.STATE_OFFLINE
+                                || rtu.state == UpgradeRtu.STATE_FAILONE
+                                || rtu.state == UpgradeRtu.STATE_FAIL
+                                || rtu.state == UpgradeRtu.STATE_FAILOFFLINE;
+                    }
+                }
+                if(qvoRtuAddr != null && !qvoRtuAddr.trim().equals("")){
+                    ok = rtu.rtuAddr.equals(qvoRtuAddr);
+                }
+                return ok;
+            }).toList() ;
+        }else{
+            return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList ;
+        }
+    }
+
+    /**
+     * 杩囨护鍑哄綋鍓嶉暱绾т换鍔′腑鍗囩骇澶辫触鐨凴TU
+     * @return 闆嗗悎
+     */
+    public List<VoUgRtuResult> exportUgFail(){
+        List<VoUgRtuResult> list = new ArrayList<>() ;
+        if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){
+            if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) {
+                RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.forEach(rtu -> {
+                    if(rtu.isOver){
+                        if(rtu.state == UpgradeRtu.STATE_OFFLINE
+                                || rtu.state == UpgradeRtu.STATE_UNSTART
+                                || rtu.state == UpgradeRtu.STATE_FAILOFFLINE){
+                            VoUgRtuResult vo = new VoUgRtuResult() ;
+                            vo.rtuAddr = rtu.rtuAddr ;
+                            vo.result = "绂荤嚎" ;
+                            list.add(vo);
+                        }else if(rtu.state == UpgradeRtu.STATE_FAILONE){
+                            VoUgRtuResult vo = new VoUgRtuResult() ;
+                            vo.rtuAddr = rtu.rtuAddr ;
+                            vo.result = "涓�鍖呮" ;
+                            list.add(vo);
+                        }else if(rtu.state == UpgradeRtu.STATE_FAIL){
+                            VoUgRtuResult vo = new VoUgRtuResult() ;
+                            vo.rtuAddr = rtu.rtuAddr ;
+                            vo.result = "澶氬寘姝�" ;
+                            list.add(vo);
+                        }
+                    }
+                });
+            }
+        }
+        return list ;
+    }
+
+    /**
+     * 杩囨护鍑哄綋鍓嶉暱绾т换鍔′腑鍗囩骇鎴愬姛鐨凴TU
+     * @return 闆嗗悎
+     */
+    public List<VoUgRtuResult> exportUgSuccess(){
+        List<VoUgRtuResult> list = new ArrayList<>() ;
+        if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){
+            if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) {
+                RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.forEach(rtu -> {
+                    if(rtu.isOver){
+                        if(rtu.state == UpgradeRtu.STATE_SUCCESS){
+                            VoUgRtuResult vo = new VoUgRtuResult() ;
+                            vo.rtuAddr = rtu.rtuAddr ;
+                            vo.result = "鍗囩骇鎴愬姛" ;
+                            list.add(vo);
+                        }
+                    }
+                });
+            }
+        }
+        return list ;
+    }
+}
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeSv.java
index 3293427..11787ec 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeSv.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeSv.java
@@ -58,28 +58,6 @@
     }
 
     /**
-     * 鏌ヨ涓�涓崌绾т换鍔℃湁鍏充俊鎭�
-     * @return 鍗囩骇浠诲姟鏈夊叧淇℃伅
-     */
-    public VoUpgradeDetail selectTaskDetail(String taskId){
-        List<VoUpgradeDetail> list = this.tdao.selectTaskDetail(Long.valueOf(taskId)) ;
-        if(list != null && list.size() > 0){
-            return list.get(0) ;
-        }
-        return null ;
-    }
-
-
-    /**
-     * 淇濆瓨鍗囩骇浠诲姟涓烘墽琛岀姸鎬�
-     * @param taskId 浠诲姟ID
-     */
-    public void setUpgradeTaskExecuted(String taskId){
-        this.tdao.executeById(Long.valueOf(taskId)) ;
-    }
-
-
-    /**
      * 淇濆瓨RTU鍗囩骇缁撴潫鐘舵��
      * @param taskId
      * @param rtu
@@ -91,17 +69,38 @@
         cdao.updateRtuUpgradeState(params) ;
     }
 
-    /////////////////////////////////////////////////////
-    //
-    // 浠ヤ笅妯℃嫙鏁版嵁
-    //
-    /////////////////////////////////////////////////////
     /**
-     * 閫氫俊涓婚敭鏌ヨ涓�涓崌绾т换鍔�
+     * 鏌ヨ涓�涓崌绾т换鍔℃湁鍏充俊鎭�
+     * @return 鍗囩骇浠诲姟鏈夊叧淇℃伅
+     */
+    public VoUpgradeDetail selectTaskDetail(String taskId){
+        List<VoUpgradeDetail> list = this.tdao.selectTaskDetail(Long.valueOf(taskId)) ;
+        if(list != null && list.size() > 0){
+            return list.get(0) ;
+        }
+        return null ;
+    }
+
+    /**
+     * 淇濆瓨鍗囩骇浠诲姟涓烘墽琛岀姸鎬�
+     * @param taskId 浠诲姟ID
+     */
+    public void setUpgradeTaskExecuted(String taskId){
+        this.tdao.executeById(Long.valueOf(taskId)) ;
+    }
+
+
+    /////////////////////////////////////////////////////
+    //
+    // 浠ヤ笅婕旂ず鍗囩骇鍔熻兘鐢ㄥ埌
+    //
+    /////////////////////////////////////////////////////
+
+    /**
+     * 鏌ヨ鏈�鏂颁竴涓崌绾т换鍔�
      * @return
      */
     public UgRtuTask selectLastTask(){
         return tdao.selectLastTask();
     }
-
 }

--
Gitblit v1.8.0