§ Oracle兼容-函数-DECODE()函数


§ 1. 语法

DECODE(
    expr,                   /* 字段或表达式 */
    search,                 /* 可能值 */
    result                  /* 返回值 */
    [, search, result ]...  /* 可选可能值/返回值对[允许多个] */
    [, default ]            /* 可选无匹配返回值 */
)
1
2
3
4
5
6
7

§ 2. 定义和用法

顾名思义,DECODE() 函数的作用是根据表达式编码/输出相应的结果,比较exprsearch的结果,如果一致则返回对应的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                                 |
+--------------------------------------+
1
2
3
4
5
6
7
8
9
10
11
12
13

greatsql-wx