COALESCE(SUM(CASE WHEN sp.auditStatus NOT IN (0, 1, 4) THEN 1 END), 0) AS failCout,
COALESCE(SUM(CASE WHEN sp.auditStatus IN (1, 4) THEN 1 END), 0) AS passCout
</if>
FROM sup_manufacturer sm
INNER JOIN sup_company sc ON sm.customerId = sc.customerId
<iftest="productStatus != null">
LEFT JOIN sup_product sp ON sm.customerId = sp.customerId AND sm.manufacturerId = sp.manufacturerIdFk
SELECT sup_manufacturer.* ,sup_company.companyName as supName
<iftest="productStatus!=null">
,(SELECT count(*) FROM sup_product WHERE sup_manufacturer.customerId=sup_product.customerId AND sup_product.auditStatus!=0 AND sup_product.auditStatus!=1 AND sup_product.auditStatus!=4 AND sup_manufacturer.manufacturerId=sup_product.manufacturerIdFk ) as failCout,
(SELECT count(*) FROM sup_product WHERE sup_manufacturer.customerId=sup_product.customerId AND (sup_product.auditStatus=1 OR sup_product.auditStatus=4) AND sup_manufacturer.manufacturerId=sup_product.manufacturerIdFk ) as passCout
</if>
FROM sup_manufacturer
inner join sup_company on sup_manufacturer.customerId = sup_company.customerId
<where>
<iftest="id != null and id != '' and type==null">
and sm.id = #{id}
and id = #{id}
</if>
<iftest="manufacturerId != null and manufacturerId != ''">
and sm.manufacturerId = #{manufacturerId}
and manufacturerId = #{manufacturerId}
</if>
<iftest="companyName != null and companyName != ''">
and sm.companyName like concat('%',#{companyName},'%')
and sup_manufacturer.companyName like concat('%',#{companyName},'%')
</if>
<iftest="creditCode != null and creditCode != ''">
and sm.creditCode like concat('%',#{creditCode},'%')
and creditCode like concat('%',#{creditCode},'%')
</if>
<iftest="placeArea != null and placeArea != ''">
and sm.placeArea like concat('%',#{placeArea},'%')
and placeArea like concat('%',#{placeArea},'%')
</if>
<iftest="customerId != null and customerId != ''">
and sm.customerId = #{customerId}
and sup_manufacturer.customerId = #{customerId}
</if>
<iftest="auditStatus != null and auditStatus !=20 and auditStatus !=21 and auditStatus !=22">
and sm.auditStatus = #{auditStatus}
and sup_manufacturer.auditStatus = #{auditStatus}
</if>
<iftest="auditStatus ==20">
and (sm.auditStatus = 0 or sm.auditStatus=5 or sm.auditStatus=2)
and (sup_manufacturer.auditStatus = 0 or sup_manufacturer.auditStatus=5 or
sup_manufacturer.auditStatus=2)
</if>
<iftest="auditStatus ==21">
and <![CDATA[ sm.auditStatus <> 0 ]]>
and <![CDATA[ sup_manufacturer.auditStatus <> 0 ]]>
</if>
<iftest="auditStatus ==22">
and (sm.auditStatus = 1 or sm.auditStatus=4 )
and (sup_manufacturer.auditStatus = 1 or sup_manufacturer.auditStatus=4 )
</if>
<iftest="lastUpdateTime!=null and lastUpdateTime!=''">
<![CDATA[ and DATE_FORMAT(sm.updateTime, '%Y-%m-%d %H:%i:%S')>= DATE_FORMAT(#{lastUpdateTime}, '%Y-%m-%d %H:%i:%S') ]]>
<![CDATA[ and DATE_FORMAT(sup_manufacturer.updateTime, '%Y-%m-%d %H:%i:%S')>= DATE_FORMAT(#{lastUpdateTime}, '%Y-%m-%d %H:%i:%S') ]]>