博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
好用的函数sign和decode
阅读量:6035 次
发布时间:2019-06-20

本文共 443 字,大约阅读时间需要 1 分钟。

      今天遇到了一个问题,需要对比一个字段和5的大小,大于5的输出0,小于五的输出1。如果是用PLSQL编程的话可以用if/else这种逻辑进行判断,但是在SQL里可不能这么写,经过网友推荐,我组合使用了sign和decode,效果很好,代码小清新。

      代码如下:

      

DECODE(SIGN(TRUNC(COL1 - COL2) - 5), 1, 0, 1) ONTIME_FLAG

      这样就可以了。

      sign函数的作用是这样的:

      如果sign的参数为负数,就会输出-1,如果为正数就会输出1,如果为0则会输出0。这样的话,加上decode,就可以按照我的想法进行计算输出了。

      而且sign是oracle提供的,其效率应该是高于自己写的逻辑的,如果自己写逻辑应该会有一个if/else。代码量也会加大,像我这样写出来的代码还是比较小清新的。希望对大家有帮助。

转载于:https://www.cnblogs.com/wingsless/archive/2012/01/08/2316202.html

你可能感兴趣的文章
linux的目录结构
查看>>
理解 JavaScript 中的 this
查看>>
Centos7关闭防火墙
查看>>
ES搜索引擎集群模式搭建【Kibana可视化】
查看>>
php去除html标签
查看>>
django常见问题
查看>>
使用eclipse上传代码到SVN服务器-----学习总结(一)
查看>>
c#4.8-4.11学习总结
查看>>
使用expdp的心得
查看>>
SIP进行时
查看>>
webmagic使用手册
查看>>
2761: [JLOI2011]不重复数字(哈希表)
查看>>
Python Revisited Day 04 (控制结构与函数)
查看>>
Robust PCA via Outlier Pursuit
查看>>
瀑布开发和敏捷开发
查看>>
struts2中的iterator标签的使用
查看>>
set global show_compatibility_56 = on;永久生效MySQL重启
查看>>
Docker for windows10 配置阿里云镜像
查看>>
Git 中文教程
查看>>
第三章:推荐系统冷启动与CB
查看>>