巧用decode() 和 sign()
简单回顾一下这两个函数
1.DECODE(exp,s1,r1,s2,r2..s,r)
2.sign(exp) 判断正负数的,如果exp为负数则返回-1,为正数则返回1,为0则返回0;exp可以为number也可以为表达式。
这两个函数都是非常重要的函数也是比较常用的函数,估计大家都已经用过n次了,但是如果把这两个函数结合起来使用就能帮我们完成between and 的功能。
1.用a b c三个变量去实验b在这三个数中的位置(顺序)
SQL> var a number;
SQL> var b number;
SQL> var c number;
SQL> exec :a:=1;:b:=2;:c:=3;
PL/SQL 过程已成功完成。
SQL> select decode(sign(:b-:c)+sign(:b-:a),-2,'最小',-1,'小于等于',0,'中间',1,'
大于等于',2,'最大') from dual;
DECODE(S
--------
中间
SQL> exec :a:=4;:b:=2;:c:=3;
;
PL/SQL 过程已成功完成。
SQL> select decode(sign(:b-:c)+sign(:b-:a),-2,'最小',-1,'小于等于',0,'中间',1,'
大于等于',2,'最大') from dual;
DECODE(S
--------
最小
SQL> exec :a:=1;:b:=2;:c:=-1;
;
PL/SQL 过程已成功完成。
SQL> select decode(sign(:b-:c)+sign(:b-:a),-2,'最小',-1,'小于等于',0,'中间',1,'
大于等于',2,'最大') from dual;
DECODE(S
--------
最大
SQL> exec :a:=2;:b:=2;:c:=3;
;
PL/SQL 过程已成功完成。
SQL> select decode(sign(:b-:c)+sign(:b-:a),-2,'最小',-1,'小于等于',0,'中间',1,'
大于等于',2,'最大') from dual;
DECODE(S
--------
小于等于
SQL> exec :a:=1;:b:=2;:c:=2;
;
PL/SQL 过程已成功完成。
SQL> select decode(sign(:b-:c)+sign(:b-:a),-2,'最小',-1,'小于等于',0,'中间',1,'
大于等于',2,'最大') from dual;
DECODE(S
--------
大于等于
SQL>
可见
sign(:b-:c)+sign(:b-:a)=-2时 b为三个数中最小,
sign(:b-:c)+sign(:b-:a)=-1时 b等于其中一个,小于另一个,
sign(:b-:c)+sign(:b-:a)=0时 b为三个数中中间的一个,
sign(:b-:c)+sign(:b-:a)=1时 b等于其中一个,大于另一个,
sign(:b-:c)+sign(:b-:a)=2时 b为三个数中最大,
这样实现between and 的功能就非常简单了
b between a and c 就等价于 decode(sign(:b-:c)+sign(:b-:a),0,XXX,-1,XXX,1,XXX).
也可以实现判断某个日期是否在某个时间段之间
select decode(sign(months_between(sysdate,sysdate-1)),1,XXX,0,XXXX,1,XXXX) from dual;
做这个简单的实验与大家share,多指教。可以把它理解成一个增强型的if else,只不过它并不通过多行语句,而是在一个函数内实现if else的功能。
select decode(:b,least(:a,:b,:c),'最小',GREATEST(:a,:b,:c),'最大','中间')
from dual
不过还要考虑一下b 和a,c相等的情况,就不是“最大”,“最小”了
随着CASE的出现,一切都失去了意义。
SIGN方法只能用于数字,字符串比较还得靠LEAST, GREATEST。
分享到:
相关推荐
DECODE
decode和encode是他们之间的转化函数 大致的过程如下 decode encode str --> str(Unicode) --> str decode()方法语法: str.decode(encoding=‘UTF-8’,errors=‘strict’) 参数: encoding – 要使用的编码...
SQL语句的DECODE和NVL,肯定能帮到你,好用!
js实现urlncode 和urldecode
主要作用:将查询结果翻译成其他值(即以其他形式表现...Select decode(columnname,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值) From talbename Where … 其中columnname为要选择的table中所定义的column,
如果不想在url中看到有明文,比如http://localhost:8080/template_1/login.action?user=张三 可以使用js的encodeURI的URLDecoder.decode一起使用一起来把url加密下 (1)JS在页面上把数据var val = encodeURI...
关于oracle decode函数的用法
avs_decode.rar
decode函数.docx
Oracle中Decode()函数使用技巧Oracle中Decode()函数使用技巧Oracle中Decode()函数使用技巧
DECODE函数相当于一条件语句(IF).它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。
本文讲述了Oracle-Decode()函数和CASE语句的比较。
Oracle中Decode()函数的有关用法Oracle中Decode()函数的有关用法
decode 加入clickhouse库之前代码
1 DECODE 中的if-then-else逻辑 在逻辑编程中,经常用到If – Then –Else 进行逻辑判断。在DECODE的语法中,实际上就是这样的逻辑处理过程。
intel graphics hd 630显卡已有硬件解码功能,linux平台下如何使用硬件解码呢?1.安装ffmpeg2.安装显卡驱动3.编译hw_decode.c #gcc -o hw_decode hw_decode.c -I/.../include -L/.../lib -lavformat -lavfilter -...
使用Decode运算符.rar使用Decode运算符.rar使用Decode运算符.rar
Decode lua调试工具。可以在exe中调试lua脚本程序。很强大!
base64decode 编码,解码。
基于J2ME的JPG decode和encode