法务dws表最新逻辑

This commit is contained in:
yangkunan 2024-08-21 09:59:05 +08:00
parent e82bfcf9af
commit 2ece6f578c
3 changed files with 123 additions and 14 deletions

View File

@ -13,6 +13,8 @@
<file url="file://$PROJECT_DIR$/dw/dwd/dwd_engine_equipment_status_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dwd/dwd_engine_stat_exception_rate_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dwd/dwd_innoveco_order_info_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dwd/dwd_law_owed_info_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dwd/dwd_law_trans_record_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dws/dws_business_bill_m.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dws/dws_business_rent_rate_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dws/dws_engine_equipment_in_good_d.sql" dialect="MySQL" />
@ -20,6 +22,7 @@
<file url="file://$PROJECT_DIR$/dw/dws/dws_engine_stat_exception_rate_w.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dws/dws_estate_incident_info_m.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dws/dws_finance_fees_serial_m.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/dws/dws_law_tran_coll_d.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/dw/ods/ods_cost_budget_data_d.sql" dialect="Oracle" />
<file url="file://$PROJECT_DIR$/finereport/kanban/mobile/创新生态_mobile.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/kanban/mobile/物业_mobile.sql" dialect="MySQL" />
@ -27,6 +30,7 @@
<file url="file://$PROJECT_DIR$/finereport/kanban/pc/商业.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/kanban/pc/工程.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/kanban/pc/总裁.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/kanban/pc/法务.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/tianbao/6_innovation/多经四大业务指标完成情况填报表.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/tianbao/EARLY_WARNING/看板数据预警-项目维度.sql" dialect="MySQL" />
<file url="file://$PROJECT_DIR$/finereport/xiazuan/2_operation/住服比异常项目.sql" dialect="MySQL" />

View File

@ -3,20 +3,90 @@ select
, case when project_name like '%撤场%' then '撤场' else '在管' end is_in_manage
, case when a.status_id in (5,6) then '诉讼'
when a.status_id in (4,7) then '非诉'
else c.case_type end is_lawsuit
, sum(a.owed_amt) trans_amt
else ifnull(c.case_type,b.case_type) end is_lawsuit
, sum(a.trans_amt) trans_amt
, count(distinct a.belong_resource) trans_household_num
, sum(d.payment_coll_amt) payment_coll_amt
, count(distinct d.belong_resource) payment_coll_num
, 0 payment_coll_amt
, 0 payment_coll_num
, b.apply_date ymd
, sum(datediff(ifnull(str_to_date(c.wjsj,'%Y-%m-%d'),current_date()),str_to_date(b.apply_date,'%Y-%m-%d'))) trans_duration
from (select * from dwd_law_owed_info_d where status_id in (0,4,5,6,7,8,9,10)) a
left join (select trans_payment, apply_date from dwd_law_trans_record_d) b
, datediff(ifnull(str_to_date(c.wjsj,'%Y-%m-%d'),current_date()),str_to_date(b.apply_date,'%Y-%m-%d')) trans_duration
, a.collect_unit
, a.acct_age
from (
select a.*
, zl acct_age -- 给所属资源打上账龄
from dwd_law_owed_info_d a
left join (
/*取高层物业费或者车位物业费作为账龄的标记*/
select *
from (
select belong_resource , cost_name , count(*) zl
, row_number() over (partition by belong_resource order by if(cost_name = '高层物业服务费',1,if(cost_name = '车位物业服务费',2,9)) asc) rn
from dwd_law_owed_info_d
where status_id in (6,7,8,9,10,11)
group by belong_resource , cost_name
) a where rn = 1
) b
on a.belong_resource = b.belong_resource
where status_id in (6,7,8,9,10,11)
) a
left join (
select a.trans_payment, a.apply_date, b.return_date , case when a.trans_type = 0 then '诉讼' else '非诉' end case_type
from dwd_law_trans_record_d a
left join dwd_law_trans_return_record_d b
on a.trans_payment = b.owed_payment
where str_to_date(a.apply_date,'%Y-%m-%d') > ifnull(date_format(b.return_date,'%Y-%m-%d'),'2000-01-01')
) b
on a.id = b.trans_payment
left join (select id, belong_resource, case_type, wjsj from dwd_law_case_info_d where status not in('作废','草稿') and belong_resource != '108926') c
on a.belong_resource = c.belong_resource
left join (select payment_coll_date, case_name, payment_coll_amt, belong_resource from dwd_law_payment_collection_d) d
on c.id = d.case_name
left join (select distinct organ_code, organ_name, comm_id, comm_name from dim_organ_mapping) e
on a.project_code = e.comm_id
group by 1,2,3,4,5,6,11
left join (
select * from (
select
a.case_type
, a.wjsj
, b.owed_id
, a.collect_unit
, row_number() over (partition by owed_id order by if(status in ('草稿','作废'),1,0) asc) rn
from dwd_law_case_info_d a
left join dwd_law_case_detail_d b
on a.id = b.case_id
) a
where rn = 1
) c
on a.id = c.owed_id
inner join (select distinct organ_code, organ_name, comm_id, comm_name from dim_organ_mapping) e
on a.project_code = e.comm_id
group by 1,2,3,4,5,6,11,12,13,14
union all
select
a.district_code organ_code
, a.district_name organ_name
, a.project_code comm_id
, a.project_name comm_name
, case when a.project_name like '%撤场%' then '撤场' else '在管' end is_in_manage
, b.case_type is_lawsuit
, 0, 0
, sum(a.payment_coll_amt) payment_coll_amt
, sum(case when a.rn =1 then 1 else 0 end) payment_coll_num
, a.apply_date ymd
, null
, b.collect_unit
, a.acct_age
from (
select a.*, b.zl acct_age, row_number() over (partition by district_code, a.belong_resource order by a.apply_date asc) rn
from dwd_law_payment_collection_d a
left join (
/*取高层物业费或者车位物业费作为账龄的标记*/
select *
from (
select belong_resource , cost_name , count(*) zl
, row_number() over (partition by belong_resource order by if(cost_name = '高层物业服务费',1,if(cost_name = '车位物业服务费',2,9)) asc) rn
from dwd_law_owed_info_d
where status_id in (6,7,8,9,10,11)
group by belong_resource , cost_name
) a where rn = 1
) b
on a.belong_resource = b.belong_resource
) a
left join dwd_law_case_info_d b
on a.case_name = b.id
group by 1,2,3,4,5,6,11,13,14

View File

@ -0,0 +1,35 @@
-- 【指标卡】
SELECT
SUM(IFNULL(trans_household_num,0)) AS ,
SUM(IFNULL(trans_amt,0))/10000 AS ,
SUM(IFNULL(payment_coll_num,0)) AS ,
SUM(IFNULL(payment_coll_amt,0))/10000 AS ,
(SUM(IFNULL(trans_amt,0)) - SUM(IFNULL(payment_coll_amt,0)))/10000 AS ,
SUM(IFNULL(trans_household_num,0)) - SUM(IFNULL(payment_coll_num,0)) AS ,
SUM(IFNULL(payment_coll_amt,0)) / SUM(IFNULL(trans_amt,0)) AS ,
SUM(IFNULL(payment_coll_num,0)) / SUM(IFNULL(trans_household_num,0)) AS
FROM dw.dws_law_tran_coll_d
WHERE left(ymd,7) = '2024-08'
WHERE left(ymd,7) <= '${p_ym}%'
${IF(LEN(p_area)!=0," AND organ_code IN ('"+JOINARRAY(p_area,"','")+"')", "")}
${if(left(fine_role,2)=="项目","and comm_name = '"+G
ETUSERDEPARTMENTS(3)+"'","")}
-- 【未移交款项】
SELECT
${IF(LEN(p_area)>0,"project_name","district_name")} AS ,
SUM(IFNULL(owed_amt,0))/10000 AS ,
SUM(IFNULL(morethan_24m_not_trans_amt,0))/10000 AS 24,
SUM(IFNULL(owed_num,0)) AS ,
SUM(IFNULL(morethan_24m_not_trans_num,0)) AS 24
FROM dws_law_not_tran_payment_m
WHERE 1=1
${IF(LEN(p_area)!=0," AND district_code IN ('"+JOINARRAY(p_area,"','")+"')", "")}
${if(left(fine_role,2)=="项目","and project_name = '"+GETUSERDEPARTMENTS(3)+"'","")}
GROUP BY
order by desc