今天遇到了一个问题,需要对比一个字段和5的大小,大于5的输出0,小于五的输出1。如果是用PLSQL编程的话可以用if/else这种逻辑进行判断,但是在SQL里可不能这么写,经过网友推荐,我组合使用了sign和decode,效果很好,代码小清新。 代码如下: 这样就可以了。 sign函数的作用是这样的: 如果sign的参数为负数,就会输出-1,如果为正数就会输出1,如果为0则会输出0。这样的话,加上decode,就可以按照我的想法进行计算输出了。 而且sign是oracle提供的,其效率应该是高于自己写的逻辑的,如果自己写逻辑应该会有一个if/else。代码量也会加大,像我这样写出来的代码还是比较小清新的。希望对大家有帮助。
DECODE(SIGN(TRUNC(COL1 - COL2) - 5), 1, 0, 1) ONTIME_FLAG
好用的函数sign和decode
原创
©著作权归作者所有:来自51CTO博客作者wingsless的原创作品,请联系作者获取转载授权,否则将追究法律责任
上一篇:有关LGWR
下一篇:使用WITH提高查询效率
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
decode and nvl and sign
值1,值2
user oracle null windows sql -
oracle decode&sign 函数联合的用法,替换 case when (zt)
decode函数可以通过比较进行内容的转换,完成的功能相当于分支语句。该函数的第一个参数为
Oracle SQL F# 系统分析员 字段 -
Oracle中的sign函数
Oracle中的sign函数
Oracle 函数 sign