From 4d3856e802d5c9d28d8654f35da426bdb517d7d4 Mon Sep 17 00:00:00 2001
From: lyfO_o <764716047@qq.com>
Date: Mon, 21 Jun 2021 10:32:27 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master' into master
---
src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml | 276 ++++++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 243 insertions(+), 33 deletions(-)
diff --git a/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml b/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
index 02acbed..9823b84 100644
--- a/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
+++ b/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
@@ -29,6 +29,7 @@
<result property="type" column="type"></result>
<result property="unitName" column="unitName"></result>
<result property="formatName" column="formatName"></result>
+ <result property="safetynum" column="safetynum"></result>
</resultMap>
<sql id="queryWhereSql">
@@ -95,6 +96,149 @@
</if>
</select>
+ <select id="reagentList" parameterType="java.util.Map" resultMap="SysReagent">
+ SELECT
+ *
+ FROM
+ (
+ 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
+ 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 f.id IS NOT NULL
+ and sr.valid_flag = 1
+ and sr.type != 3
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%", #{cas} ,"%")
+ </if>
+ <if test="supplierId != null and supplierId != ''">
+ and sr.supplier_id = #{supplierId}
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%", #{productSn} ,"%")
+ </if>
+ UNION ALL
+ 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
+ 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}
+ AND f.id IS NULL
+ where sr.valid_flag = 1
+ and sr.type != 3
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%", #{cas} ,"%")
+ </if>
+ <if test="supplierId != null and supplierId != ''">
+ and sr.supplier_id = #{supplierId}
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%", #{productSn} ,"%")
+ </if>
+ <if test="MaxSize != null">
+ limit #{MaxSize}
+ </if>
+ ) as reagent
+ ORDER BY reagent.favortime DESC,length(reagent.name),price asc
+ <if test="first != null and pageSize != null">
+ limit #{first}, #{pageSize}
+ </if>
+ </select>
+
+
+ <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
+ 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
+ <choose>
+ <when test="favorFlag != ''">
+ and f.id is not null
+ </when>
+ <otherwise>
+ and f.id is null
+ </otherwise>
+ </choose>
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%",#{cas},"%")
+ </if>
+ <if test="supplierId != null and supplierId != ''">
+ and sr.supplier_id = #{supplierId}
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%",#{productSn},"%")
+ </if>
+ <choose>
+ <when test="favorFlag != ''">
+ ORDER BY favortime desc
+ </when>
+ <otherwise>
+ ORDER BY sr.create_time desc
+ </otherwise>
+ </choose>
+ <if test="first != null and pageSize != null">
+ limit #{first}, #{pageSize}
+ </if>
+ </select>
+
+ <select id="favorCount" parameterType="java.util.Map" resultType="int">
+ select count(1)
+ 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
+ <choose>
+ <when test="favorFlag != ''">
+ and f.id is not null
+ </when>
+ <otherwise>
+ and f.id is null
+ </otherwise>
+ </choose>
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%",#{cas},"%")
+ </if>
+ <if test="supplierId != null and supplierId != ''">
+ and sr.supplier_id = #{supplierId}
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%",#{productSn},"%")
+ </if>
+ </select>
<select id="getSysReagentListNew" parameterType="java.util.Map" resultMap="SysReagent">
select sr.*, ss.meta_value as product_home_name, ifnull(w.reserve,0) as reserve, bm.meta_value as control_products_name,supplier.name as supplierName
@@ -115,10 +259,13 @@
<if test="name != null and name != ''">
and sr.name like concat("%", #{name} ,"%")
</if>
- <if test="type != null and type != ''">
+ <if test="type != null">
and sr.type = #{type}
</if>
- ORDER BY sr.create_time desc
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%", #{productSn} ,"%")
+ </if>
+ ORDER BY length(sr.name),sr.create_time desc
<if test="first != null and pageSize != null">
limit #{first}, #{pageSize}
</if>
@@ -140,6 +287,28 @@
</if>
</select>
+ <select id="reagentCount" parameterType="java.util.Map" resultType="int">
+ select count(1)
+ 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
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%", #{cas} ,"%")
+ </if>
+ <if test="supplierId != null and supplierId != ''">
+ and sr.supplier_id = #{supplierId}
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%", #{productSn} ,"%")
+ </if>
+ </select>
+
<select id="getSysReagentTotalCountNew" parameterType="java.util.Map" resultType="int">
select count(1)
from sys_reagent as sr
@@ -153,10 +322,21 @@
<if test="name != null and name != ''">
and sr.name like concat("%", #{name} ,"%")
</if>
- <if test="type != null and type != ''">
+ <if test="type != null">
and sr.type = #{type}
</if>
+ <if test="productSn != null and productSn != ''">
+ and sr.product_sn like concat("%", #{productSn} ,"%")
+ </if>
+ </select>
+ <select id="getReagentUnitByReagentId" parameterType="java.lang.String" resultType="java.lang.String">
+ SELECT bm.meta_value
+ from sys_reagent sr
+ LEFT JOIN base_meta bm on bm.id = sr.reagent_unit
+ where sr.valid_flag =1
+ and bm.valid_flag = 1
+ and sr.id = #{reagentId}
</select>
@@ -172,41 +352,66 @@
<select id="getSysReagentByCas" parameterType="com.nanometer.smartlab.entity.SysReagent" resultMap="SysReagent">
select * From sys_reagent where type=1 and valid_flag = 1
- <if test="cas!=null and cas!=''">
- and cas = #{cas}
+ <if test="productSn!=null and productSn!=''">
+ and product_sn = #{productSn}
</if>
- <if test="cas==null or cas==''">
- and cas is null
- </if>
- <if test="mainMetering!=null and mainMetering!=''">
- and main_metering = #{mainMetering}
- </if>
- <if test="mainMetering==null or mainMetering==0">
- and main_metering is null
- </if>
- <if test="reagentUnit!=null and reagentUnit!=''">
- and reagent_unit=#{reagentUnit}
- </if>
- <if test="reagentUnit==null or reagentUnit==''">
- and reagent_unit is null
- </if>
- <if test="reagentFormat!=null and reagentFormat!=''">
- and reagent_format=#{reagentFormat}
- </if>
- <if test="reagentFormat==null or reagentFormat==''">
- and reagent_format is null
- </if>
- <if test="productHome!=null and productHome!=''">
- and product_home = #{productHome}
- </if>
- <if test="productHome==null or productHome==''">
- and product_home is null
+ <if test="supplierId!=null and supplierId!=''">
+ and supplier_id = #{supplierId}
</if>
</select>
+ <select id="getReagent" resultMap="SysReagent">
+ select * From sys_reagent
+ where type=3
+ and valid_flag = 1
+ <if test="name!=null and name!=''">
+ and name =#{name}
+ </if>
+ <if test="cas!=null and cas!=''">
+ and cas =#{cas}
+ </if>
+ <if test="packing!=null and packing!=''">
+ and reagent_unit =#{packing}
+ </if>
+ <if test="factory!=null and factory!=''">
+ and product_home =#{factory}
+ </if>
+ <if test="specifications!=null and specifications!=''">
+ and reagent_format =#{specifications}
+ </if>
+
+ </select>
+ <select id="selectReagentSafetyNum" resultMap="SysReagent">
+ select
+ sr.id,
+ sr.product_sn,
+ sr.cas,
+ sr.safetynum,
+ sr.name,
+ sr.main_metering,
+ sr.productSn,
+ sr.cas,
+ bm1.meta_value reagent_unit,
+ bm2.meta_value reagent_type,
+ bm3.meta_value reagent_format,
+ bm4.meta_value product_home,
+ ss.meta_value as product_home_name,
+ bm.meta_value as control_products_name,
+ supplier.name as supplierName
+ 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 base_meta bm1 on bm1.id = sr.reagent_unit
+ left join base_meta bm2 on bm2.id = sr.reagent_type
+ left join base_meta bm3 on bm3.id = sr.reagent_format
+ left join base_meta bm4 on bm4.id = sr.product_home
+ where sr.valid_flag = 1
+ and sr.type = 1
+ and safetynum > 0
+ </select>
-
- <insert id="insertSysReagent" parameterType="com.nanometer.smartlab.entity.SysReagent">
+ <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>
@@ -261,4 +466,9 @@
#{item}
</foreach>
</update>
+ <update id="updateSafetyNum">
+ update sys_reagent
+ set safetynum = #{safetynum}
+ where id = #{id}
+ </update>
</mapper>
--
Gitblit v1.9.2