admin管理员组文章数量:1794759
SQL中如何处理除数为0的情况?
点击关注上方“SQL数据库开发”,
设为“置顶或星标”,第一时间送达干货
SQL专栏
SQL基础知识第二版SQL高级知识第二版
问题
我们在进行数据统计的时候,经常会遇到求百分比,环比,同比等这些需要除以某个数的情况,而如果除数为0,数据库是会报错的。
那么遇到这样的情况我们怎么处理呢?下面我们用示例给大家讲解一下处理方法。
解决办法
情况一
例如
SELECT A/B FROM TAB遇到这样的情况,一般的处理方法是用CASE WHEN来判断B的值
SELECT CASE WHEN B=0 THEN 0 ELSE A/B END FROM TAB这样当B如果是0,我们直接赋一个值,避免A/B参与计算报错。
情况二
上面是一种常见的情况,但是如果遇到下面这样的聚合函数呢?
例如
SELECT SUM(A)/COUNT(B) FROM TAB遇到这样的情况CASE WHEN 是不能判断COUNT(B)的值的,因为WHEN后面的条件不能使用聚合函数(语法要求),这个时候我们可以这样处理
SELECT ISNULL(SUM(A)/NULLIF(COUNT(B),0),0) FROM TAB其中这里使用了两个函数,NULLIF()和ISNULL() NULLIF函数有两个参数,定义如下:
NULLIF( expression1 , expression2 )
其作用就是:如果两个指定的表达式相等,就返回NULL值。
ISNULL函数也有两个参数,定义如下:
ISNULL( expression1 , expression2 )
其作用是:如果第一个参数的结果为NULL,就返回第二个参数的值。
当COUNT(B)的结果为0时,恰好与第二个给定的参数0相等,这个时候NULLIF函数就会返回NULL,而SUM(A)在除以NULL时结果为NULL,外层使用ISNULL函数再对NULL值进行判断,这样最终结果就是0了。
这两种方法就是我们日常处理除数为0的情况了,一定要记得哦~
最后给大家分享我写的SQL两件套:《SQL基础知识第二版》和《SQL高级知识第二版》的PDF电子版。里面有各个语法的解释、大量的实例讲解和批注等等,非常通俗易懂,方便大家跟着一起来实操。
有需要的读者可以下载学习,在下面的公众号「数据前线」(非本号)后台回复关键字:SQL,就行
数据前线
后台回复关键字:1024,获取一份精心整理的技术干货
后台回复关键字:进群,带你进入高手如云的交流群。
推荐阅读
知乎:国家何时整治程序员的高薪现象?
SQL触发器实战
一款SQL自动检查神器,再也不用担心SQL出错了!
SQL如何求解连续年份的问题?
SQL 语法速成手册
版权声明:本文标题:SQL中如何处理除数为0的情况? 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1687070077a131118.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论