COUNT(CASE WHEN c.type = 1 AND c.auditStatus != 0 THEN 1 END) AS supCertCount,
COUNT(CASE WHEN c.type = 1 AND c.auditStatus = 1 THEN 1 END) AS supCertOkCount,
COUNT(CASE WHEN c.type = 1 AND c.auditStatus = 6 THEN 1 END) AS supCertNotCount,
<iftest="manufacturerStatus != null">
COALESCE(SUM(CASE WHEN sm.auditStatus NOT IN (0, 1, 4) THEN 1 END), 0) AS failCout,
COALESCE(SUM(CASE WHEN sm.auditStatus IN (1, 4) THEN 1 END), 0) AS passCout,
COALESCE(SUM(CASE WHEN sp.auditStatus NOT IN (0, 1, 4) THEN 1 END), 0) AS productFailCout,
COALESCE(SUM(CASE WHEN sp.auditStatus IN (1, 4) THEN 1 END), 0) AS productPassCout
</if>
FROM sup_company sc
LEFT JOIN sup_cert c ON sc.customerId = c.customerId
*,
(select count(1) from sup_cert c where sup_company.customerId = c.customerId and type = 1 and auditStatus != 0 ) as 'supCertCount',
(select count(1) from sup_cert c where sup_company.customerId = c.customerId and type = 1 and auditStatus = 1 ) as 'supCertOkCount',
(select count(1) from sup_cert c where sup_company.customerId = c.customerId and type = 1 and auditStatus = 6 ) as 'supCertNotCount'
<iftest="manufacturerStatus!=null">
,(SELECT count(*) FROM sup_manufacturer WHERE sup_company.customerId=sup_manufacturer.customerId AND sup_manufacturer.auditStatus!=1 AND sup_manufacturer.auditStatus!=0 AND sup_manufacturer.auditStatus!=4 ) as failCout,
(SELECT count(*) FROM sup_manufacturer WHERE sup_company.customerId=sup_manufacturer.customerId AND (sup_manufacturer.auditStatus=1 OR sup_manufacturer.auditStatus=4) ) as passCout
,(SELECT count(*) FROM sup_product WHERE sup_company.customerId=sup_product.customerId AND sup_product.auditStatus!=0 AND sup_product.auditStatus!=1 AND sup_product.auditStatus!=4 ) as productFailCout,
(SELECT count(*) FROM sup_product WHERE sup_company.customerId=sup_product.customerId AND (sup_product.auditStatus=1 OR sup_product.auditStatus=4) ) as prouctPassCout
</if>
FROM sup_company
<where>
<iftest="customerId != null and customerId != ''">
and sc.customerId = #{customerId}
and customerId = #{customerId}
</if>
<iftest="companyName != null and companyName != ''">
and sc.companyName like concat('%',#{companyName},'%')
and companyName like concat('%',#{companyName},'%')
</if>
<iftest="creditNum != null and creditNum != ''">
and sc.creditNum like concat('%',#{creditNum},'%')
and creditNum like concat('%',#{creditNum},'%')
</if>
<iftest="auditStatus != null and auditStatus !=20 and auditStatus !=21 and auditStatus !=22">
and sc.auditStatus = #{auditStatus}
and auditStatus = #{auditStatus}
</if>
<iftest="auditStatus ==20">
and (sc.auditStatus = 0 or sc.auditStatus=5 or sc.auditStatus=2)
and (auditStatus = 0 or auditStatus=5 or auditStatus=2)
</if>
<iftest="auditStatus ==21">
and <![CDATA[ sc.auditStatus <> 0 ]]>
and <![CDATA[ auditStatus <> 0 ]]>
</if>
<iftest="auditStatus ==22">
and (sc.auditStatus = 1 or sc.auditStatus=4 )
and (auditStatus = 1 or auditStatus=4 )
</if>
<iftest="unitIdFk != null and unitIdFk != ''">
and sc.unitIdFk = #{unitIdFk}
and unitIdFk = #{unitIdFk}
</if>
<iftest="lastUpdateTime!=null and lastUpdateTime!=''">
<![CDATA[ and DATE_FORMAT(sc.updateTime, '%Y-%m-%d %H:%i:%S')>= DATE_FORMAT(#{lastUpdateTime}, '%Y-%m-%d %H:%i:%S') ]]>
<![CDATA[ and DATE_FORMAT(updateTime, '%Y-%m-%d %H:%i:%S')>= DATE_FORMAT(#{lastUpdateTime}, '%Y-%m-%d %H:%i:%S') ]]>