lyfO_o
2021-06-11 ea5cbe91b94e48e9f63947d01decdf919848ae91
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,181 @@
    </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
    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
    <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="type != null">
      and sr.type = #{type}
    </if>
    <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>
  </select>
  <select id="getSysReagentTotalCount" parameterType="java.util.Map" resultType="int">
    select count(1)
    from sys_reagent as sr
@@ -111,6 +287,59 @@
    </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
    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="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>
  <select id="getSysReagentByCas2" parameterType="com.nanometer.smartlab.entity.SysReagent" resultMap="SysReagent">
    select * From sys_reagent where type=0 and valid_flag = 1
    <if test="cas!=null and cas!=''">
@@ -123,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>
@@ -212,4 +462,9 @@
      #{item}
    </foreach>
  </update>
  <update id="updateSafetyNum">
    update sys_reagent
    set safetynum = #{safetynum}
    where id = #{id}
  </update>
</mapper>