From ea5cbe91b94e48e9f63947d01decdf919848ae91 Mon Sep 17 00:00:00 2001 From: lyfO_o <764716047@qq.com> Date: 星期五, 11 六月 2021 17:35:36 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' into master --- src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml | 268 +++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 237 insertions(+), 31 deletions(-) diff --git a/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml b/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml index 21a0e40..248d804 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 @@ -118,7 +262,10 @@ <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 @@ -156,7 +325,18 @@ <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,62 @@ <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.safetynum, + sr.name, + sr.main_metering, + 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 +462,9 @@ #{item} </foreach> </update> + <update id="updateSafetyNum"> + update sys_reagent + set safetynum = #{safetynum} + where id = #{id} + </update> </mapper> -- Gitblit v1.9.2