- 【版权所有,文章允许转载,但须以链接方式注明源地址,否则追究法律责任】
- 【创作不易,点个赞就是对我最大的支持】
前言
仅作为学习笔记,供大家参考
总结的不错的话,记得点赞收藏关注哦!
将结果集作为列
case when 条件 then else 用法,如果条件满足则等于then后边的值,否则就是else值
-- 统计按建筑业资质等级
select year_months,jzyzzdj,COUNT(data_match),
sum(case when data_match=1 then 1 else 0 end) as a,
sum(case when data_match=2 then 1 else 0 end) as b,
sum(case when data_match=3 then 1 else 0 end) as c,
sum(case when data_match=4 then 1 else 0 end) as d
FROM gc_qy_hlxfx
GROUP BY jzyzzdj ORDER BY jzyzzdj
求百分比保留两位小数
IFNULL(CAST((t.jzyzczsydlj-t.jzyzczsndtqlj) / t.jzyzczsndtqlj * 100 AS decimal(18,2)),0.00) as tqdbzf
创作不易,点个赞就是对我最大的支持~
wxgzh:程序员温眉
CSDN:程序员温眉
每天进步一点点的程序员
文章介绍了如何在SQL中使用CASEWHEN语句统计不同条件的结果,并计算百分比,保留两位小数。示例查询展示了在建筑业资质等级数据上的应用,以及如何处理可能的零除问题。
2132

被折叠的 条评论
为什么被折叠?



