kongzy
2024-07-01 47a751cb301d05276ae5d75145d57b2d090fe4e1
src/main/java/com/nanometer/smartlab/dao/SysReagentDao.xml
@@ -25,7 +25,6 @@
    <result property="controlProducts" column="control_products"></result>
    <result property="controlProductsName" column="control_products_name"></result>
    <result property="productHome" column="product_home"></result>
    <result property="productHomeName" column="product_home_name"></result>
    <result property="type" column="type"></result>
    <result property="unitName" column="unitName"></result>
    <result property="formatName" column="formatName"></result>
@@ -63,27 +62,21 @@
left join base_meta d on d.id=a.product_home
where a.valid_flag = 1
</select>
  <select id="getSysReagent" parameterType="java.lang.String"  resultMap="SysReagent" >
  <select id="getSysReagent"   resultMap="SysReagent" >
    select * from sys_reagent
    where id = #{id} and valid_flag = 1
  </select>
  <select id="getSysReagentDetail" parameterType="java.lang.String" resultType="java.util.Map">
    select sr.name ,sr.main_metering,sr.memo  memo,sr.product_sn productCode,bm.meta_value reagentFormat  ,sm.meta_value controlProducts,am.meta_value unit
  <select id="getSysReagentDetail"  resultType="java.util.Map">
    select sr.name ,sr.main_metering,sr.memo  memo,sr.product_sn productCode,sr.reagent_format as reagentFormat  ,sr.control_products as controlProducts,sr.reagent_unit as unit
        from sys_reagent sr
    left join base_meta  bm on bm.id = sr.reagent_format
      LEFT JOIN base_meta sm  on sr.control_products = sm.id
      LEFT JOIN base_meta am on sr.reagent_unit = am.id
    where sr.id = #{id} and sr.valid_flag = 1
  </select>
  <select id="getSysReagentList" 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,f.id favor,f.create_time favortime
    select sr.*,  ifnull(w.reserve,0)  as reserve,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 (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
@@ -104,17 +97,12 @@
    (
    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,
    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}
@@ -137,17 +125,12 @@
    UNION ALL
    (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,
    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}
@@ -172,7 +155,7 @@
    </if>
    )
    ) as reagent
    ORDER BY reagent.favortime DESC,length(reagent.name),reagent.order_index,price asc
    ORDER BY reagent.favortime DESC,length(reagent.name),price asc
    <if test="first != null and pageSize != null">
      limit #{first}, #{pageSize}
    </if>
@@ -180,9 +163,7 @@
  <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
    select sr.id,sr.name,sr.cas,sr.product_sn,sr.create_time,sr.update_time from sys_reagent sr
    <where>
        and sr.valid_flag = 1 and sr.type=1
      <if test="cas != null and cas != ''">
@@ -209,15 +190,12 @@
  </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,
    select sr.*,
    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
@@ -258,8 +236,6 @@
  <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
@@ -287,14 +263,12 @@
  </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
    select sr.*,ifnull(w.reserve,0)  as reserve, 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 (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 or sr.type = 0)
    and (supplier.valid_flag = 1)
    <if test="cas != null and cas != ''">
      and sr.cas = #{cas}
    </if>
@@ -304,7 +278,7 @@
    <if test="name != null and name != ''">
      and sr.name like concat("%", #{name} ,"%")
    </if>
    <if test="type != null">
    <if test="type != null and type != ''">
      and sr.type = #{type}
    </if>
    <if test="productSn != null and productSn != ''">
@@ -319,8 +293,6 @@
  <select id="getSysReagentTotalCount" 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}
@@ -334,8 +306,6 @@
  <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
@@ -359,9 +329,12 @@
    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 or sr.type = 0)
    and (ss.valid_flag = 1)
    <if test="cas != null and cas != ''">
        and sr.cas = #{cas}
    </if>
    <if test="type != null">
      and sr.type = #{type}
    </if>
    <if test="supplierId != null and supplierId != ''">
        and sr.supplier_id = #{supplierId}
@@ -369,20 +342,15 @@
    <if test="name != null and name != ''">
        and sr.name like concat("%", #{name} ,"%")
    </if>
    <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
  <select id="getReagentUnitByReagentId"  resultType="java.lang.String">
   SELECT sr.reagent_unit
  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>
@@ -429,36 +397,19 @@
  </select>
    <select id="selectReagentSafetyNum" resultMap="SysReagent">
      select
      sr.id,
      sr.product_sn,
      sr.cas,
      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,
      sr.*,
      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 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 id="insertSysReagent" parameterType="com.nanometer.smartlab.entity.SysReagent" useGeneratedKeys = "true" keyProperty = "id">
    insert into sys_reagent(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 ( #{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">
@@ -527,29 +478,23 @@
    select
    *
    from sys_reagent as sr
    left join base_meta bm2 on sr.reagent_character = bm2.id
    left join base_meta bm4 on sr.reagent_unit = bm4.id
    left join base_meta bm5 on sr.product_home = bm5.id
    left join base_meta bm6 on sr.reagent_format = bm6.id
    left join base_meta bm7 on sr.reagent_type = bm7.id
    left join sys_supplier supply on sr.supplier_id = supply.id
    <where>
      sr.valid_flag = 1
      <if test="params.packing != null and params.packing != ''">
        and UPPER(concat(sr.main_metering,bm4.meta_value) ) = UPPER(#{params.packing})
      </if>
      <if test="params.product_home != null and params.product_home != ''">
        and bm5.meta_value = #{params.product_home}
        and sr.product_home = #{params.product_home}
      </if>
      <if test="params.reagent_character != null and params.reagent_character != ''">
        and bm2.meta_value = #{params.reagent_character}
        and sr.params.reagent_character = #{params.reagent_character}
      </if>
      <if test="params.reagent_format != null and params.reagent_format != ''">
        and bm6.meta_value = #{params.reagent_format}
        and sr.params.reagent_format = #{params.reagent_format}
      </if>
      <if test="params.reagent_type != null and params.reagent_type != ''">
        and bm7.meta_value = #{params.reagent_type}
        and sr.reagent_type = #{params.reagent_type}
      </if>
      <if test="params.cas != null and params.cas != ''">
        and sr.cas = #{params.cas}
@@ -569,31 +514,16 @@
  <select id="getRowData" resultMap="SysReagent">
        select
        a.*,
        main_metering,
        reagent_unit,
        reagent_format,
        product_home,
        b.meta_value unitName,
        c.meta_value formatName,
        d.meta_value product_home_name,
        e.meta_value control_products_name,
        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
        left join base_meta d on d.id=a.product_home
        left join base_meta e on e.id=a.control_products
        left join sys_supplier s ON s.id = a.supplier_id
        where a.id = #{id}
  </select>
  <select id="getSysReagentListNewRowData" 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
     select sr.*, ifnull(w.reserve,0)  as reserve,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 (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
@@ -601,28 +531,10 @@
  </select>
  <select id="selectAll" resultType="java.util.Map">
    select
    sr.name,
    sr.product_sn as productSn,
    sr.cas,
    sr.price,
    sr.per_box as perBox,
    sr.safetynum,
    sr.*,
    CASE WHEN type = 0 THEN '耗材' WHEN type = 1 THEN '试剂' ELSE '' END AS kind,
    ss.meta_value as productHomeName,
    bm.meta_value as control_products_name,
    supplier.name as supplierName,
    bm1.meta_value as reagentType,
    bm2.meta_value as reagentCharacter,
    bm3.meta_value as reagentFormat,
    CONCAT(sr.main_metering,bm4.meta_value) as reagentUnit
    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 base_meta bm1   on bm1.id = sr.reagent_type
    left join base_meta bm2   on bm2.id = sr.reagent_character
    left join base_meta bm3   on bm3.id = sr.reagent_format
    left join base_meta bm4   on bm4.id = sr.reagent_unit
    left join sys_supplier supplier on supplier.id = sr.supplier_id
    where sr.valid_flag = 1
    <if test="cas != null and cas != ''">