From 7f01ee9b40b5ee18f53caed2132bbe6150975b3f Mon Sep 17 00:00:00 2001
From: gdg <764716047@qq.com>
Date: Tue, 01 Dec 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