liyu
2020-12-02 366659f2bc5226a8da99489e89fb8f5b7c6aec9f
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
@@ -115,7 +212,7 @@
    <if test="name != null and name != ''">
      and sr.name like concat("%", #{name} ,"%")
    </if>
    <if test="type != null and type != ''">
    <if test="type != null">
      and sr.type = #{type}
    </if>
    ORDER BY sr.create_time desc
@@ -125,6 +222,22 @@
  </select>
  <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}
    where sr.valid_flag = 1
    <include refid="queryWhereSql"/>
    <if test="favor != null and favor != '' ">
      and f.id is not null
    </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
@@ -153,7 +266,7 @@
    <if test="name != null and name != ''">
        and sr.name like concat("%", #{name} ,"%")
    </if>
    <if test="type != null and type != ''">
    <if test="type != null">
      and sr.type = #{type}
    </if>