From 1e159ffbf027d1c8a2de5a92ff257d3b02411415 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Sat, 06 Aug 2022 16:50:11 +0800
Subject: [PATCH] 修复使用农资后,已出库待使用农资数据不变。修复使用农资后还能删除出库数据

---
 src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml |   62 ++++++++++++++++++++++++++-----
 1 files changed, 52 insertions(+), 10 deletions(-)

diff --git a/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml b/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml
index f790a3a..fc1ed16 100644
--- a/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml
+++ b/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml
@@ -17,13 +17,16 @@
 
     <select id="selectLandPage" resultMap="landResultMap">
         SELECT l.land_name,
+        l.land_unit,
         l.id,
         l.land_area ,
         ST_ASTEXT(land_range) as land_range,
         l.url,
         d.dict_value as dic,
         c.dict_value as dica,
-        v.farm_name as deptname
+        v.farm_name as deptname,
+        l.farm_id as farmId,
+        l.land_type
         FROM `sys_land` l
         LEFT JOIN (SELECT dict_key, dict_value FROM blade_dict_biz WHERE CODE = 'land' AND is_deleted = 0 <if
         test="land.tenantId!=null and land.tenantId != ''">
@@ -135,6 +138,16 @@
         type = #{land.type},
         land_unit = #{land.landUnit},
         farm_id = #{land.farmId},
+        url = #{land.url}
+        where id = #{land.id}
+    </update>
+
+    <update id="updateLandAr">
+        update sys_land set user_id = #{land.userId},
+        land_area = #{land.landArea},
+        <if test="land.landRange!=null and land.landRange!=''">
+            land_range = ST_GeomFromText(${land.landRange}),
+        </if>
         url = #{land.url},
         where id = #{land.id}
     </update>
@@ -152,9 +165,6 @@
         <if test="land.farmId!= null and land.farmId!=''">
             and farm_id=#{land.farmId}
         </if>
-        <if test="land.deptId!= null and land.deptId!=''">
-            and dept_id=#{land.deptId}
-        </if>
     </select>
     <!--土地使用面积-->
     <select id="selectSAre" resultType="java.util.HashMap">
@@ -165,9 +175,6 @@
         <if test="land.farmId!= null and land.farmId!=''">
             and farm_id=#{land.farmId}
         </if>
-        <if test="land.deptId!= null and land.deptId!=''">
-            and dept_id=#{land.deptId}
-        </if>
     </select>
     <!--土地未使用面积-->
     <select id="selectWAre" resultType="java.util.HashMap">
@@ -177,9 +184,6 @@
         and type = 1
         <if test="land.farmId!= null and land.farmId!=''">
             and farm_id=#{land.farmId}
-        </if>
-        <if test="land.deptId!= null and land.deptId!=''">
-            and dept_id=#{land.deptId}
         </if>
     </select>
 
@@ -196,4 +200,42 @@
         GROUP BY sfp.strain_id
     </select>
 
+    <!--查询统计地块是否有轮廓-->
+    <select id="getLandIsAreaStatistic" resultType="java.lang.Integer">
+        SELECT count(*) FROM sys_land where land_range is not null
+        <if test="land.farmId!= null and land.farmId!=''">
+            and farm_id=#{land.farmId}
+        </if>
+        <if test="land.deptId!= null and land.deptId!=''">
+            and dept_id=#{land.deptId}
+        </if>
+        union all
+        SELECT count(*) FROM sys_land where land_range is null
+        <if test="land.farmId!= null and land.farmId!=''">
+            and farm_id=#{land.farmId}
+        </if>
+        <if test="land.deptId!= null and land.deptId!=''">
+            and dept_id=#{land.deptId}
+        </if>
+    </select>
+
+    <select id="selectByStrainId" resultType="org.springblade.modules.lang.entity.Land">
+        SELECT land.id,land.land_name,land.url,land.farm_id
+        FROM sys_land land
+            LEFT JOIN sys_farm_product_stock fps ON fps.land_id = land.id
+        WHERE fps.strain_id = #{strainId}
+        <if test="farmId !=null and farmId != '' ">
+            AND land.farm_id = #{farmId}
+        </if>
+    </select>
+    <select id="getByStrainIdFarmId" resultType="org.springblade.modules.lang.entity.Land">
+        SELECT land.id,land.land_name,land.url,land.farm_id
+        FROM sys_land land
+        LEFT JOIN sys_farm_plant sfp ON sfp.land_id = land.id
+        WHERE sfp.strain_id = #{strainId}
+        <if test="farmId !=null and farmId != '' ">
+            AND land.farm_id = #{farmId}
+        </if>
+    </select>
+
 </mapper>

--
Gitblit v1.9.3