Oracle数据库Decode()函数的使用方法
DECODE函数的作用 它可以将输入数值与函数中的参数列表相比较 根据输入值返回一个对应值 函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式 当然 如果未能与任何一个实参序偶匹配成功 则函数也有默认的返回值 DECODE函数的作用 它可以将输入数值与函数中的参数列表相比较 根据输入值返回一个对应值 函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式 当然 如果未能与任何一个实参序偶匹配成功 则函数也有默认的返回值 区别于SQL的其它函数 DECODE函数还能识别和操作空值 语法如下 DECODE(control_value value result [ value result …][ default_result]); control _value 试图处理的数值 DECODE函数将该数值与后面的一系列的偶序相比较 以决定返回值 value 是一组成序偶的数值 如果输入数值与之匹配成功 则相应的结果将被返回 对应一个空的返回值 可以使用关键字NULL于之对应 result 是一组成序偶的结果值 default_result 未能与任何一个值匹配时 函数返回的默认值 示例如下 select decode( x ‘x is ’ ‘x is ’ ‘others’) from dual 当x等于 时 则返回‘x is ’ 当x等于 时 则返回‘x is ’ 否则 返回others’ 在需要比较 个值的时候 我们可以配合SIGN()函数一起使用 SELECT DECODE( SIGN( ) Is Positive Is Nagative Is Zero ) 同样 也可以用CASE实现 SELECT CASE SIGN( ) WHEN THEN Is Positive WHEN THEN Is Nagative ELSE Is Zero END FROM DUAL 另外 大家还可以在Order by中使用Decode 例 表table_subject 有subject_name列 要求按照 语 数 外的顺序进行排序 这时 就可以非常轻松的使用Decode完成要求了 lishixinzhi/Article/program/Oracle/201311/19054
oracle中decode函数有什么用?
DECODE函数相当于一条件语句(IF).它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回值。区别于SQL的其它函数,DECODE函数还能识别和操作空值.
其具体的语法格式如下:
DECODE(input_value,value,result[,value,result…][,default_result]);
其中:
input_value
试图处理的数值。DECODE函数将该数值与一系列的序偶相比较,以决定最后的返回结果
value
是一组成序偶的数值。如果输入数值与之匹配成功,则相应的结果将被返回。对应一个空的返回值,可以使用关键字NULL于之对应
result
是一组成序偶的结果值
default_result
未能与任何一序偶匹配成功时,函数返回的默认值
下面的例子说明了,如何读取用户CHECKUP表SEAPARK中的BLOOD_TEST_FLAG列下的项目,作为DECODE函数的实参支持值。
SELECT
checkup_type,
DECODE(blood_test_flag,’Y’,’Yes’,’N’,’No’,NULL,’None’,’Invalid’)
FROM
checkup;

