OrderBaseCMapper.xml 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <mapper namespace="com.gree.mall.miniapp.commonmapper.workorder.OrderBaseCMapper">
  4. <select id="countOrderStatus" resultType="com.gree.mall.miniapp.bean.workorder.CountOrderStatusBean">
  5. select
  6. count(DISTINCT if((is_import_excel = false and a.order_status='DJD') or (is_import_excel = true and a.is_meet = false) ,a.id,null)) 'djd',
  7. count(DISTINCT if(a.order_status in ('FWZ','GCSZT','BFWG','DSM','YZP','XSBH','TJXSBH','ZBBH','FZXBH','WDBH') and a.is_meet = true,a.id,null)) 'fwz',
  8. count(DISTINCT if(a.is_exception=1,a.id,null)) 'ycd',
  9. count(DISTINCT if(a.order_status='DQD',a.id,null)) 'dqd',
  10. count(DISTINCT if(a.order_status in ('YWG','YJS','GCSZX','YWGO','WDWG'),a.id,null)) 'ywg',
  11. count(DISTINCT if(a.over_time between date(now()) and now(),a.id,null)) 'jrwg',
  12. count(DISTINCT if(a.order_status in ('YWG','YJS','GCSZX','YWGO','WDWG'),a.id,null)) 'jbnwg',
  13. count(DISTINCT if(a.order_status not in ('YWG','YJS','GCSZX','YWGO','WDWG','DQD'),a.id,null)) 'WWG',
  14. COUNT(DISTINCT a.id) AS 'all'
  15. from pg_order_base a
  16. left join pg_order_worker b on a.id = b.order_base_id
  17. where ((b.worker_id=#{workerId} or b.worker_number=#{workerNumber}) or a.order_status = 'DQD') and a.order_status not in ('YQX','FWQX','FL','FWZT','YCGB')
  18. <if test="isYb != null and isYb == true">
  19. and a.pg_incre_order_id != ''
  20. </if>
  21. <if test="isWb != null and isWb == true">
  22. and a.rp_project_repair_id !=''
  23. </if>
  24. <if test="pgIncreOrderId != null and pgIncreOrderId !=''">
  25. and a.pg_incre_order_id = #{pgIncreOrderId}
  26. </if>
  27. and a.company_wechat_id = #{companyWechatId}
  28. and a.create_time > date_sub(now(),INTERVAL 180 day)
  29. </select>
  30. <select id="countPartsApply" resultType="com.gree.mall.miniapp.bean.workorder.CountOrderStatusBean">
  31. SELECT
  32. SUM(IF(a.status = 'ING', 1, 0)) AS 'ping',
  33. SUM(IF(a.status = 'END' AND b.order_status IN ('FWZ','YCD'), 1, 0)) AS 'pend'
  34. FROM
  35. websit_parts_apply a JOIN pg_order_base b
  36. WHERE
  37. a.create_by_id = #{userId}
  38. AND a.status IN ('ING', 'END')
  39. </select>
  40. </mapper>