Oracle兼容-函数-DECODE()函数
1. 语法
DECODE(
expr, /* 字段或表达式 */
search, /* 可能值 */
result /* 返回值 */
[, search, result ]... /* 可选可能值/返回值对[允许多个] */
[, default ] /* 可选无匹配返回值 */
)
2. 定义和用法
顾名思义,DECODE()
函数的作用是根据表达式编码/输出相应的结果,比较expr
和search
的结果,如果一致则返回对应的result
,如果所有条件都不匹配则返回default
,如果default
不存在,则返回NULL。
对于expr=search=NULL
,的情况与Oracle行为一致,会返回第一个search
为NULL的result
。
注意:可能值与返回值的评估使用短路评估
,即:只要存在expr
\=search
则后续search
不会被评估。
3. 示例
greatsql> SELECT DECODE(1, 1, 'one', 2, 'two', 'other');
+----------------------------------------+
| DECODE(1, 1, 'one', 2, 'two', 'other') |
+----------------------------------------+
| one |
+----------------------------------------+
greatsql> SELECT DECODE(NULL, 1, 'one', NULL, 'NULL');
+--------------------------------------+
| DECODE(NULL, 1, 'one', NULL, 'NULL') |
+--------------------------------------+
| NULL |
+--------------------------------------+
问题反馈
联系我们
扫码关注微信公众号