免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3950 | 回复: 2
打印 上一主题 下一主题

case 中过滤了除数为0的情况,但postgresql是否还会检测除数是否为0? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-10-18 14:31 |只看该作者 |倒序浏览
有个sql语句,类似于

select
case  when aa!=0 then bb/aa end, aa, bb from ttt;

同样的语句以及同样的数据,在oracle中正常运行,在postgresql(事实上我用的是greenplum)中却报“ERROR:  cannot take logarithm of zero  (seg4 gpsdw5-1:50001 pid=14552)”的错误,个人感觉应该是除数为0造成的

请教一下各位大侠,postgresql中是不是不管你前面有否case过滤,查询时都会检测除数是否为0的情况?

如果确实如此,遇到这种情况,我应该怎么改写sql比较好呢?

论坛徽章:
1
寅虎
日期:2013-09-29 23:15:15
2 [报告]
发表于 2010-10-18 22:06 |只看该作者
在一个表中实测返回的
select case when aa!= 0 then bb/aa end, bb, aa from ttt;
            case            |  bb| aa
----------------------------+-----------+---------
     0.00000000000000000000 |      0.00 |     500
     0.00000000000000000000 |      0.00 |     500
     0.00000000000000000000 |      0.00 |     500
                            |  60000.00 |       0
                            |  60000.00 |       0
                            |  60000.00 |       0
                            |  60000.00 |       0
                            |  60000.00 |       0
     0.00000000000000000000 |      0.00 |    1000
     0.00000000000000000000 |      0.00 |    1000
     0.00000000000000000000 |      0.00 |    1000

论坛徽章:
0
3 [报告]
发表于 2010-10-19 09:59 |只看该作者
谢谢楼上的,后来经过我进一步的排查,原来不是这个问题,真是不好意思,
我sql中有另外的power的运算,而在greenplum中对power(0,x),如果x不是整数的话,不管其是否大于1,都会报这个错,而我在原始的开源postgresql-8.4.5中,没有这个错误,因此可以认为该问题并非postgresql的错误,而是greenplum产生的一个bug,或者说greenplum不支持该写法

针对以上问题,我们移植代码时,可以将power中第一个参数的值加上0.000000000000000001
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP