From 15c0421c864198b125c30589fa43c50eaa00b36e Mon Sep 17 00:00:00 2001
From: lyfO_o <764716047@qq.com>
Date: 星期五, 10 二月 2023 10:30:02 +0800
Subject: [PATCH] 中国科学院重庆绿色智能技术研究院 配置

---
 src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml |   47 ++++++++++++++++++++++++++++++++---------------
 1 files changed, 32 insertions(+), 15 deletions(-)

diff --git a/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml b/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
index 6cb3fa6..ffc7672 100644
--- a/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
+++ b/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
@@ -30,6 +30,7 @@
     <result property="unitName" column="unitName"></result>
     <result property="formatName" column="formatName"></result>
     <result property="safetynum" column="safetynum"></result>
+    <result property="density" column="density"></result>
   </resultMap>
 
   <sql id="queryWhereSql">
@@ -108,7 +109,8 @@
     bm.meta_value AS control_products_name,
     supplier. NAME AS supplierName,
     f.id favor,
-    f.create_time favortime
+    f.create_time favortime,
+    supplier.valid_flag  as supplierFlag
     FROM
     sys_reagent AS sr
     LEFT JOIN base_meta AS ss ON sr.product_home = ss.id
@@ -118,7 +120,7 @@
     AND f.user_id= #{user}
     WHERE f.id IS NOT NULL
     and sr.valid_flag = 1
-    and supplier.valid_flag = 1
+    and (supplier.valid_flag = 1 or sr.type = 0)
     and sr.type != 3
     <if test="cas != null and cas != ''">
       and sr.cas like concat("%", #{cas} ,"%")
@@ -133,14 +135,15 @@
       and sr.product_sn like concat("%", #{productSn} ,"%")
     </if>
     UNION ALL
-    SELECT
+    (SELECT
     sr.*,
     ss.meta_value AS product_home_name,
     ss.order_index,
     bm.meta_value AS control_products_name,
     supplier.NAME AS supplierName,
     f.id favor,
-    f.create_time favortime
+    f.create_time favortime,
+    supplier.valid_flag as supplierFlag
     FROM
     sys_reagent AS sr
     LEFT JOIN base_meta AS ss ON sr.product_home = ss.id
@@ -150,7 +153,7 @@
     AND f.user_id = #{user}
     AND f.id IS NULL
     where sr.valid_flag = 1
-    and supplier.valid_flag = 1
+    and (supplier.valid_flag = 1 or sr.type = 0)
     and sr.type != 3
     <if test="cas != null and cas != ''">
       and sr.cas like concat("%", #{cas} ,"%")
@@ -167,6 +170,7 @@
     <if test="MaxSize != null">
       limit #{MaxSize}
     </if>
+    )
     ) as reagent
     ORDER BY reagent.favortime DESC,length(reagent.name),reagent.order_index,price asc
     <if test="first != null and pageSize != null">
@@ -176,13 +180,19 @@
 
 
   <select id="favorList" parameterType="java.util.Map" resultMap="SysReagent">
-    select sr.*, ss.meta_value as product_home_name, bm.meta_value as control_products_name,supplier.name as supplierName,f.id favor,f.create_time favortime
+    select sr.*, ss.meta_value as product_home_name,
+    bm.meta_value as control_products_name,
+    supplier.name as supplierName,
+    f.id favor,
+    f.create_time favortime,
+    supplier.valid_flag  as supplierFlag
     from sys_reagent as sr
     left join base_meta as ss on sr.product_home = ss.id
     left join base_meta bm	on bm.id = sr.control_products
     left join sys_supplier supplier on supplier.id = sr.supplier_id
     LEFT JOIN favor f on f.reagent_id = sr.id AND f.user_id = #{user}
     where sr.valid_flag = 1
+    and (supplier.valid_flag = 1 or sr.type = 0)
     <choose>
       <when test="favorFlag != ''">
         and f.id is not null
@@ -224,6 +234,7 @@
     left join sys_supplier supplier on supplier.id = sr.supplier_id
     LEFT JOIN favor f on f.reagent_id = sr.id AND f.user_id = #{user}
     where sr.valid_flag = 1
+    and (supplier.valid_flag = 1 or sr.type = 0)
     <choose>
       <when test="favorFlag != ''">
        and f.id is not null
@@ -254,7 +265,7 @@
     left join (select reagent_id, sum(reserve) reserve from ope_warehouse_reserve where valid_flag = 1 group by reagent_id) w on w.reagent_id = sr.id
     left join sys_supplier supplier on supplier.id = sr.supplier_id
     where sr.valid_flag = 1
-    and supplier.valid_flag = 1
+    and (supplier.valid_flag = 1 or sr.type = 0)
     <if test="cas != null and cas != ''">
       and sr.cas = #{cas}
     </if>
@@ -282,7 +293,6 @@
     left join base_meta as ss on sr.product_home = ss.id
     left join base_meta bm	on bm.id = sr.control_products
     left join (select reagent_id, sum(reserve) reserve from ope_warehouse_reserve where valid_flag = 1 group by reagent_id) w on w.reagent_id = sr.id
-
     left join sys_supplier supplier on supplier.id = sr.supplier_id
     LEFT JOIN favor f on f.reagent_id = sr.id AND f.user_id = #{user}
     where sr.valid_flag = 1
@@ -300,7 +310,7 @@
     left join sys_supplier supplier on supplier.id = sr.supplier_id
     LEFT JOIN favor f on f.reagent_id = sr.id AND f.user_id = #{user}
     where sr.valid_flag = 1
-    and supplier.valid_flag = 1
+    and (supplier.valid_flag = 1 or sr.type = 0)
     <if test="cas != null and cas != ''">
       and sr.cas like concat("%", #{cas} ,"%")
     </if>
@@ -320,7 +330,7 @@
     from sys_reagent as sr
     LEFT JOIN sys_supplier ss on ss.id = sr.supplier_id
     where sr.valid_flag = 1
-    and ss.valid_flag = 1
+    and (ss.valid_flag = 1 or sr.type = 0)
     <if test="cas != null and cas != ''">
         and sr.cas = #{cas}
     </if>
@@ -418,14 +428,14 @@
 
 
     <insert id="insertSysReagent" parameterType="com.nanometer.smartlab.entity.SysReagent">
-    insert into sys_reagent(id, name, cas, reagent_type, reagent_character, supplier_id, reagent_format, main_metering, reagent_unit, price, per_box, memo, valid_flag, create_time, update_time,deadline, product_sn, dangerous_flag,control_products,product_home,type)
-    values (#{id}, #{name}, #{cas}, #{reagentType}, #{reagentCharacter}, #{supplierId}, #{reagentFormat}, #{mainMetering}, #{reagentUnit}, #{price}, #{perBox}, #{memo}, 1, now(), now(),#{deadline}, #{productSn}, #{dangerousFlag},#{controlProducts},#{productHome},#{type})
+    insert into sys_reagent(id, name, cas, reagent_type, reagent_character, supplier_id, reagent_format, main_metering, reagent_unit, price, per_box, memo, valid_flag, create_time, update_time,deadline, product_sn, dangerous_flag,control_products,product_home,type,density)
+    values (#{id}, #{name}, #{cas}, #{reagentType}, #{reagentCharacter}, #{supplierId}, #{reagentFormat}, #{mainMetering}, #{reagentUnit}, #{price}, #{perBox}, #{memo}, 1, now(), now(),#{deadline}, #{productSn}, #{dangerousFlag},#{controlProducts},#{productHome},#{type},#{density})
   </insert>
 
   <update id="updateSysReagent" parameterType="com.nanometer.smartlab.entity.SysReagent">
     update sys_reagent set name=#{name}, cas=#{cas}, reagent_type=#{reagentType}, reagent_character=#{reagentCharacter}, supplier_id=#{supplierId}, reagent_format=#{reagentFormat},
     main_metering=#{mainMetering}, reagent_unit=#{reagentUnit}, price=#{price}, per_box=#{perBox}, memo=#{memo}, update_time=now(), deadline = #{deadline}, product_sn = #{productSn}, dangerous_flag = #{dangerousFlag}, control_products = #{controlProducts}
-    ,product_home=#{productHome},type=#{type}
+    ,product_home=#{productHome},type=#{type},density = #{density}
     where id=#{id}
   </update>
 
@@ -477,8 +487,14 @@
     set safetynum = #{safetynum}
     where id = #{id}
   </update>
+    <update id="updateSysReagentPriceById">
+      update sys_reagent
+      set price = #{price}
+      where id = #{reagentId}
 
-  <select id="countReagentByDetail" resultMap="SysReagent">
+    </update>
+
+    <select id="countReagentByDetail" resultMap="SysReagent">
     select
     *
     from sys_reagent as sr
@@ -532,7 +548,8 @@
         c.meta_value formatName,
         d.meta_value product_home_name,
         e.meta_value control_products_name,
-        s.name AS supplierName
+        s.name AS supplierName,
+        s.valid_flag  as supplierFlag
         from sys_reagent a
         left join base_meta b on b.id=a.reagent_unit
         left join base_meta c on c.id=a.reagent_format

--
Gitblit v1.9.2