首页 > 数据库 > mysql教程 > 如何计算单个SQL SELECT语句中两列之间匹配值的百分比?

如何计算单个SQL SELECT语句中两列之间匹配值的百分比?

Mary-Kate Olsen
发布: 2024-12-28 19:58:10
原创
273 人浏览过

How to Calculate the Percentage of Matching Values Between Two Columns in a Single SQL SELECT Statement?

在 SQL 中的单个 SELECT 语句中通过 SUM() 计算百分比

在“my_obj”表的上下文中,该表包含两个整数字段(“value_a”)和“value_b”),您试图确定“value_a”等于的实例的百分比'value_b'.

简单高效的方法

为了获得最佳性能和简单性,请考虑以下修改后的查询:

SELECT property_name
      ,(count(value_a = value_b OR NULL) * 100) / count(*) AS pct
FROM   my_obj
GROUP  BY 1;
登录后复制

This方法利用“count()”的功能来忽略“NULL”值,确保两列都被考虑在内。将匹配值的数量乘以 100,然后除以总数量,即可计算出百分比。

包括小数位

如果需要小数位结果,在计算中使用“100.0”而不是“100”并考虑使用'round()':

SELECT property_name
      ,round((count(value_a = value_b OR NULL) * 100.0) / count(*), 2) AS pct
FROM   my_obj
GROUP  BY 1;
登录后复制

此修订版本确保计算仍然是数字,保留小数值并允许报告的百分比具有更高的精度。

以上是如何计算单个SQL SELECT语句中两列之间匹配值的百分比?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板