From 7f01ee9b40b5ee18f53caed2132bbe6150975b3f Mon Sep 17 00:00:00 2001 From: gdg <764716047@qq.com> Date: 星期二, 01 十二月 2020 17:52:04 +0800 Subject: [PATCH] 申购试剂-试剂库优化 --- src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml | 113 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 113 insertions(+), 0 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..f067e14 100644 --- a/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml +++ b/src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml @@ -95,6 +95,103 @@ </if> </select> + <select id="reagentList" parameterType="java.util.Map" resultType="int"> + 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 + <if test="cas != null and cas != ''"> + and sr.cas = #{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 = #{productSn} + </if> + ORDER BY sr.create_time desc + <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 = #{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 = #{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 = #{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 = #{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 @@ -140,6 +237,22 @@ </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 (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 + <include refid="queryWhereSql"/> + <if test="favor != null and favor != '' "> + and f.id is not null + </if> + </select> + <select id="getSysReagentTotalCountNew" parameterType="java.util.Map" resultType="int"> select count(1) from sys_reagent as sr -- Gitblit v1.9.2