From e33bca52d26faa836a4db7436e85eb3a0a08adff Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期二, 19 八月 2025 17:26:02 +0800
Subject: [PATCH] 1、增加查询所有作物昨日蒸腾量功能; 2、增加查询一个作物一段时间内容所有蒸腾量功能。

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/MdEt0Mapper.xml                           |   37 +++++++++
 pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporSv.java   |   45 +++++++++++
 pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporCtrl.java |   95 +++++++++++++++++++++++
 pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporQo.java   |   38 +++++++++
 pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoMd/MdEt0.java                 |    9 ++
 pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoMd/MdEt0Mapper.java            |    8 ++
 6 files changed, 232 insertions(+), 0 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoMd/MdEt0Mapper.java b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoMd/MdEt0Mapper.java
index a24b5d6..4c3da28 100644
--- a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoMd/MdEt0Mapper.java
+++ b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoMd/MdEt0Mapper.java
@@ -2,10 +2,13 @@
 
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.dy.pipIrrGlobal.pojoMd.MdEt0;
+import com.dy.pipIrrGlobal.voRm.VoManure;
 import org.apache.ibatis.annotations.Mapper;
 import org.apache.ibatis.annotations.Param;
 
 import java.util.Date;
+import java.util.List;
+import java.util.Map;
 
 /**: This is a mapper interface for database operations on the MdEt0 entity.
  *               It provides basic CRUD (Create, Read, Update, Delete) functionality.
@@ -34,4 +37,9 @@
     int updateByPrimaryKeySelective(MdEt0 record);
 
     int updateByPrimaryKey(MdEt0 record);
+
+    List<MdEt0> selectEt0ByDt(@Param("ymd")String ymd) ;
+
+    List<MdEt0> selectEt0ByCropAndDt(Map<?, ?> params);
+
 }
\ No newline at end of file
diff --git a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoMd/MdEt0.java b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoMd/MdEt0.java
index b46d01e..21ea5a0 100644
--- a/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoMd/MdEt0.java
+++ b/pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoMd/MdEt0.java
@@ -3,6 +3,7 @@
 import com.alibaba.fastjson2.annotation.JSONField;
 import com.alibaba.fastjson2.writer.ObjectWriterImplToString;
 import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
 import com.baomidou.mybatisplus.annotation.TableId;
 import com.baomidou.mybatisplus.annotation.TableName;
 import com.dy.common.po.BaseEntity;
@@ -80,4 +81,12 @@
     @Schema(description = "鏈棩浣滅墿钂歌吘閲�", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
     public Double et0;
 
+    /**
+     * 闈炴暟鎹簱琛ㄥ睘鎬�
+     * 鍏宠仈鐨� 浣滅墿鍚嶇О
+     */
+    @Schema(description = "鍏宠仈鐨勪綔鐗╁悕绉�", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
+    @TableField(exist = false)
+    public String cropName;
+
 }
\ No newline at end of file
diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/MdEt0Mapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/MdEt0Mapper.xml
index 0109084..82e870b 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/MdEt0Mapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/MdEt0Mapper.xml
@@ -17,6 +17,12 @@
     <!--@mbg.generated-->
     id, crop_id, weather_id, factor, max_tmp, min_tmp, dt, et0
   </sql>
+  <sql id="Base_Column_List_with_alias">
+    <!--@mbg.generated-->
+    ${alias}.id, ${alias}.crop_id, ${alias}.weather_id,
+    ${alias}.factor, ${alias}.max_tmp, ${alias}.min_tmp,
+    ${alias}.dt, ${alias}.et0
+  </sql>
   <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
     <!--@mbg.generated-->
     select 
@@ -33,6 +39,37 @@
     and weather_id = #{weatherId,jdbcType=BIGINT}
     and dt = #{dt,jdbcType=DATE}
   </select>
+
+  <select id="selectEt0ByDt" resultMap="BaseResultMap">
+    <!--@mbg.generated-->
+    select
+    <include refid="Base_Column_List_with_alias" >
+      <property name="alias" value="et"/>
+    </include>,
+    mc.name as cropName
+    from md_et0 et
+    inner join md_crops mc on et.crop_id = mc.id
+    where mc.stopped != 1 and et.dt = #{ymd,jdbcType=DATE}
+  </select>
+  <!--鏍规嵁鎸囧畾鏉′欢鏌ヨ璁板綍-->
+  <select id="selectEt0ByCropAndDt" resultType="com.dy.pipIrrGlobal.pojoMd.MdEt0">
+    SELECT
+    <include refid="Base_Column_List_with_alias" >
+      <property name="alias" value="htb"/>
+    </include>,
+    mc.name as cropName
+    from md_et0 et
+    inner join md_crops mc on et.crop_id = mc.id
+    <where>
+      <if test="cropId != null">
+        AND et.crop_id = #{cropId}
+      </if>
+      <if test = "timeStart != null and timeStart !='' and timeStop != null and timeStop != ''">
+        AND et.dt BETWEEN #{timeStart} AND #{timeStop}
+      </if>
+    </where>
+    ORDER BY et.id ASC
+  </select>
   <delete id="deleteByPrimaryKey" parameterType="java.lang.Long">
     <!--@mbg.generated-->
     delete from md_et0
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporCtrl.java
new file mode 100644
index 0000000..c5a7395
--- /dev/null
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporCtrl.java
@@ -0,0 +1,95 @@
+package com.dy.pipIrrModel.vapor;
+
+import com.dy.common.aop.SsoAop;
+import com.dy.common.util.DateTime;
+import com.dy.common.webUtil.BaseResponse;
+import com.dy.common.webUtil.BaseResponseUtils;
+import com.dy.common.webUtil.ResultCodeMsg;
+import com.dy.pipIrrGlobal.pojoMd.MdEt0;
+import com.dy.pipIrrGlobal.voRm.VoManure;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.media.Content;
+import io.swagger.v3.oas.annotations.media.Schema;
+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 lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+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.RestController;
+
+import java.util.List;
+
+/**
+ * @Author: liurunyu
+ * @Date: 2025/8/19 16:21
+ * @Description
+ */
+@Slf4j
+@Tag(name = "浣滅墿鏃ヨ捀鑵鹃噺", description = "浣滅墿鏃ヨ捀鑵鹃噺鏌ヨ绛夋搷浣�")
+@RestController
+@RequestMapping(path = "mdVapor")
+public class VaporCtrl {
+
+    private VaporSv sv;
+
+    @Autowired
+    private void setSv(VaporSv sv) { this.sv = sv; }
+
+
+    /**
+     * 瀹㈡埛绔姹傚緱鍒版墍鏈変綔鐗╃殑鏄ㄦ棩钂歌吘閲�
+     * @return 鎵�鏈夋墍鏈変綔鐗╃殑鏄ㄦ棩钂歌吘閲�
+     */
+    @Operation(summary = "鑾峰緱浣滅墿鐨勬槰鏃ヨ捀鑵鹃噺", description = "杩斿洖鎵�鏈変綔鐗╃殑鏄ㄦ棩钂歌吘閲忔暟鎹�")
+    @ApiResponses(value = {
+            @ApiResponse(
+                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
+                    description = "杩斿洖浣滅墿鐨勬槰鏃ヨ捀鑵鹃噺鏁版嵁锛圔aseResponse.content:QueryResultVo[{}]锛�",
+                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
+                            schema = @Schema(implementation = MdEt0.class))}
+            )
+    })
+    @GetMapping(path = "allYesterday")
+    @SsoAop()
+    public BaseResponse<List<MdEt0>> allYesterday(){
+        try {
+            String ymd = DateTime.yesterday_yyyy_MM_dd(
+                    Integer.parseInt(DateTime.yyyy()),
+                    Integer.parseInt(DateTime.MM()),
+                    Integer.parseInt(DateTime.dd())) ;
+            List<MdEt0> res = this.sv.selectEt0(ymd) ;
+            return BaseResponseUtils.buildSuccess(res);
+        } catch (Exception e) {
+            log.error("鏌ヨ鎵�鏈変綔鐗╃殑鏄ㄦ棩钂歌吘閲忓紓甯�", e);
+            return BaseResponseUtils.buildException(e.getMessage()) ;
+        }
+    }
+
+    /**
+     * 鏍规嵁鎸囧畾鏉′欢浣滅墿鏌ヨ涓�娈垫椂闂村唴鐨勮捀鑵鹃噺
+     * @param qo
+     * @return
+     */
+    @GetMapping(path = "oneCropsSomeEt0")
+    @SsoAop()
+    public BaseResponse<List<VoManure>> oneCropsSomeEt0(VaporQo qo){
+        try {
+            if(qo.cropId == null){
+                return BaseResponseUtils.buildFail("浣滅墿id涓嶈兘涓虹┖") ;
+            }
+            if(qo.timeStop == null || qo.timeStop.trim().equals("")){
+                qo.timeStop = DateTime.yyyy_MM_dd() ;
+            }
+            if(qo.timeStart == null || qo.timeStart.trim().equals("")){
+                qo.timeStart = DateTime.lastXDay_yyyy_MM_dd(qo.timeStop, 10);
+            }
+            return BaseResponseUtils.buildSuccess(sv.oneCropsSomeEt0(qo));
+        } catch (Exception e) {
+            return BaseResponseUtils.buildException(e.getMessage()) ;
+        }
+    }
+
+}
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporQo.java b/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporQo.java
new file mode 100644
index 0000000..c4c8e85
--- /dev/null
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporQo.java
@@ -0,0 +1,38 @@
+package com.dy.pipIrrModel.vapor;
+
+import com.dy.common.webUtil.QueryConditionVo;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.*;
+
+/**
+ * @Author: liurunyu
+ * @Date: 2025/8/19 16:21
+ * @Description
+ */
+
+@Data
+@EqualsAndHashCode(callSuper = false)
+@ToString(callSuper = true)
+@NoArgsConstructor
+@AllArgsConstructor
+@Builder
+@Schema(name = "浣滅墿鏃ヨ捀鑵炬煡璇㈡潯浠�")
+public class VaporQo extends QueryConditionVo {
+    /**
+     * 浣滅墿ID
+     */
+    @Schema(description = "浣滅墿ID", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
+    public Long cropId;
+    /**
+     * 鏌ヨ寮�濮嬫棩鏈�
+     */
+    @Schema(description = "鏌ヨ寮�濮嬫棩鏈�", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
+    public String timeStart;
+
+    /**
+     * 鏌ヨ缁撴潫鏃ユ湡
+     */
+    @Schema(description = "鏌ヨ缁撴潫鏃ユ湡", requiredMode = Schema.RequiredMode.NOT_REQUIRED)
+    public String timeStop;
+
+}
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporSv.java
new file mode 100644
index 0000000..ee0ee44
--- /dev/null
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-model/src/main/java/com/dy/pipIrrModel/vapor/VaporSv.java
@@ -0,0 +1,45 @@
+package com.dy.pipIrrModel.vapor;
+
+import com.dy.common.util.DateTime;
+import com.dy.common.webUtil.BaseResponse;
+import com.dy.common.webUtil.BaseResponseUtils;
+import com.dy.common.webUtil.QueryResultVo;
+import com.dy.pipIrrGlobal.daoMd.MdEt0Mapper;
+import com.dy.pipIrrGlobal.pojoMd.MdEt0;
+import com.dy.pipIrrGlobal.voRm.VoManure;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.dubbo.common.utils.PojoUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @Author: liurunyu
+ * @Date: 2025/8/19 16:21
+ * @Description
+ */
+
+@Slf4j
+@Service
+public class VaporSv {
+
+    private MdEt0Mapper mdEt0Dao;
+
+    @Autowired
+    private void setDao( MdEt0Mapper mdEt0Dao) {
+        this.mdEt0Dao = mdEt0Dao;
+    }
+
+    public List<MdEt0> selectEt0(String ymd){
+       return mdEt0Dao.selectEt0ByDt(ymd);
+    }
+
+    public List<MdEt0> oneCropsSomeEt0(VaporQo qo){
+       Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo);
+       return mdEt0Dao.selectEt0ByCropAndDt(params);
+    }
+
+
+}

--
Gitblit v1.8.0