MySQL统计数量以及百分比

一、使用什么函数?

  1.count(*)/count(字段名)
COUNT(*) 计算表中总的行数,无论某列有数值或者为空值。

COUNT(字段名)计算指定列下总的行数,计算时将忽略空值的行。

   2.concat(str1, str2,...)
返回结果为连接参数产生的字符串,如果有任何一个参数为null,则返回值为null。

   3.round(x,d) /round(x)
round(x,d)  --  x指要处理的数,d是指保留几位小数

round(x,d)  --  同round(x,0),即不保存小数

二、具体实例

1.sql语句

SELECT
	create_time AS time,
	SUM( CASE WHEN state = "online" THEN 1 ELSE 0 END ) AS onlineCnt,-------计算online状态数量
	CONCAT( ROUND( SUM( CASE WHEN state = "online" THEN 1 ELSE 0 END ) / COUNT( state ) * 100, 2 ), '%' ) AS per -------计算百分比
FROM
	dev_device_history 
WHERE
	create_time <= '2023-07-26' AND create_time >= '2023-07-12' 
	AND product_id = "ywy_aep" 
	AND factory IN ( "杭水科技" )----------筛选条件 
GROUP BY
	create_time --------按时间分组

SUM( CASE WHEN state = "online" THEN 1 ELSE 0 END ) AS onlineCnt------计算online状态数量

COUNT( state )-------总数量


 CONCAT( ROUND( SUM( CASE WHEN state = "online" THEN 1 ELSE 0 END ) / COUNT( state ) * 100, 2 ), '%' ) AS per--------计算所占全部状态的百分比

  2.输出结果

 完结撒花  欢迎大家留言

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值