一些语句.sql 2.4 KB

12345678910111213141516171819202122232425
  1. -- 重复工单
  2. with t1 as (select compl_area_local,busi_no from report_auto.he_d_mobile_comp hdmc where month_id = substring('20230420' from 1 for 6) and day_id <= substring('20230420' from 7 for 2)),
  3. t2 as (select distinct * from t1),
  4. t3 as (select compl_area_local, count(1) as total_num from t1 group by compl_area_local),
  5. t4 as (select compl_area_local, count(1) as distinct_num from t2 group by compl_area_local),
  6. t5 as (select t3.compl_area_local, t3.total_num, t3.total_num - t4.distinct_num as repeat_num, (t3.total_num - t4.distinct_num)/t3.total_num::numeric as repeat_ratio from T3, t4 where t3.compl_area_local = t4.compl_area_local)
  7. select '全省' as compl_area_local, sum(total_num) as total_num, sum(repeat_num) as repeat_num, sum(repeat_num) /sum(total_num)::numeric as repeat_ratio from t5
  8. union select * from t5
  9. -- 超时工单
  10. with t1 as (select compl_area_local, is_timeout from report_auto.he_d_mobile_comp hdmc where month_id = substring('20230420' from 1 for 6) and day_id <= substring('20230420' from 7 for 2)),
  11. t2 as (select '全省' as compl_area_local, count(1) as total_num from t1),
  12. t3 as (select compl_area_local, count(1) as total_num from t1 group by compl_area_local),
  13. t4 as (select * from t2 union select * from t3),
  14. t5 as (select compl_area_local from t1 where is_timeout = '是'),
  15. t7 as (select '全省' as compl_area_local, count(1) as timeout_num from t5),
  16. t8 as (select compl_area_local, count(1) as timeout_num from t5 group by compl_area_local),
  17. t9 as (select * from t7 union select * from t8)
  18. select t4.compl_area_local, t4.total_num, t9.timeout_num, t9.timeout_num/t4.total_num::numeric as timeout_ratio from t4,t9 where t4.compl_area_local = t9.compl_area_local order by t9.timeout_num/t4.total_num::numeric desc
  19. -- 超时时间
  20. with t1 as (select compl_area_local, case when proce_time != '' then (extract('epoch' from to_timestamp(proce_time, 'YYYY-MM-DD HH24:MI:SS')) - extract('epoch' from to_timestamp(accept_time, 'YYYY-MM-DD HH24:MI:SS')))/3600 when is_online_complete = '是' then 0
  21. else (extract('epoch' from to_timestamp(end_time, 'YYYY-MM-DD HH24:MI:SS')) - extract('epoch' from to_timestamp(accept_time, 'YYYY-MM-DD HH24:MI:SS')))/3600 end as duration
  22. from report_auto.he_d_mobile_comp hdmc where month_id = substring('20230420' from 1 for 6) and day_id <= substring('20230420' from 7 for 2))
  23. select compl_area_local, avg(duration) as avg_duration from t1 group by compl_area_local