题解 | #分析客户逾期情况#

分析客户逾期情况

https://www.nowcoder.com/practice/22633632da344e2492973ecf555e10c9

select pay_ability,concat(round(100*(over_num/(over_num+not_over_num)),1),"%") as "overdue_ratio"
from(

select mid_t1.pay_ability,over_num,not_over_num
from(
select pay_ability,coalesce(count(case when over_mark=1 then 1 end), 0) as "over_num"
from(
select pay_ability, if(overdue_days is not null, 1,0) as "over_mark",
if(overdue_days is null, 1,0) as "not_over_mark"
from loan_tb lt left join customer_tb ct
on lt.customer_id = ct.customer_id
)t1
group by pay_ability
)mid_t1 join (

select pay_ability,coalesce(count(case when over_mark=0 then 1 end), 0) as "not_over_num"
from(
select pay_ability, if(overdue_days is not null, 1,0) as "over_mark",
if(overdue_days is null, 1,0) as "not_over_mark"
from loan_tb lt join customer_tb ct
on lt.customer_id = ct.customer_id
)t1
group by pay_ability
) mid_t2 
on mid_t1.pay_ability = mid_t2.pay_ability
)final_t
order by overdue_ratio desc

全部评论

相关推荐

评估中了已经
投递小米集团等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务