From 59d9ea33f503e363f2e2941c7c00cc9dd9d9d1c7 Mon Sep 17 00:00:00 2001
From: kongzy <kongzy>
Date: Tue, 28 Nov 2023 11:00:42 +0800
Subject: [PATCH] 修改课题管理bug
---
src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml | 76 ++++++++++++++++++++++++++++++-------
1 files changed, 61 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..db8de67 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">
@@ -175,14 +179,49 @@
</select>
+ <select id="reagentSimpleInfoList" resultMap="SysReagent">
+ select sr.id,sr.name,sr.cas,sr.product_sn,sr.create_time,sr.update_time,bm.meta_value as reagent_type,bm2.meta_value as reagent_character from sys_reagent sr
+ left join base_meta as bm on bm.id=sr.reagent_type
+ left join base_meta as bm2 on bm2.id=sr.reagent_character
+ <where>
+ and sr.valid_flag = 1 and sr.type=1
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%", #{cas} ,"%")
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ </where>
+ order by sr.create_time desc
+ limit #{first},#{pageSize}
+ </select>
+ <select id="reagentSimpleInfoCount" resultType="int">
+ select count(1) from sys_reagent sr
+ <where>
+ and sr.valid_flag = 1 and sr.type=1
+ <if test="cas != null and cas != ''">
+ and sr.cas like concat("%", #{cas} ,"%")
+ </if>
+ <if test="name != null and name != ''">
+ and sr.name like concat("%", #{name} ,"%")
+ </if>
+ </where>
+ </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
+ 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 +263,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 +294,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 +322,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 +339,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 +359,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 +457,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 +516,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 +577,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