CASE表达式
CASE
表达式使用条件来过滤nGQL查询语句的结果,常用于YIELD
和RETURN
子句中。和openCypher一样,nGQL提供两种形式的CASE
表达式:简单形式和通用形式。
CASE
表达式会遍历所有条件,并在满足第一个条件时停止读取后续条件,然后返回结果。如果不满足任何条件,将通过ELSE
子句返回结果。如果没有ELSE
子句且不满足任何条件,则返回NULL
。
下图为本文的示例图。
简单形式
语法
CASE <comparer>
WHEN <value> THEN <result>
[WHEN ...]
[ELSE <default>]
END
!!! caution
`CASE`表达式一定要用`END`结尾。
参数 | 说明 |
---|---|
comparer | 用于与value 进行比较的值或者有效表达式。 |
value | 和comparer 进行比较,如果匹配,则满足此条件。 |
result | 如果value 匹配comparer ,则返回该result 。 |
default | 如果没有条件匹配,则返回该default 。 |
示例
nebula> RETURN \
CASE 2+3 \
WHEN 4 THEN 0 \
WHEN 5 THEN 1 \
ELSE -1 \
END \
AS result;
+--------+
| result |
+--------+
| 1 |
+--------+
nebula> GO FROM "player100" OVER follow \
YIELD $$.player.name AS Name, \
CASE $$.player.age > 35 \
WHEN true THEN "Yes" \
WHEN false THEN "No" \
ELSE "Nah" \
END \
AS Age_above_35;
+---------------------+--------------+
| Name | Age_above_35 |
+---------------------+--------------+
| "Tony Parker" | "Yes" |
+---------------------+--------------+
| "LaMarcus Aldridge" | "No" |
+---------------------+--------------+
通用形式
语法
CASE
WHEN <condition> THEN <result>
[WHEN ...]
[ELSE <default>]
END
参数 | 说明 |
---|---|
condition | 如果条件condition 为true,表示满足此条件。 |
result | condition 为true,则返回此result 。 |
default | 如果没有条件匹配,则返回该default 。 |
示例
nebula> YIELD \
CASE WHEN 4 > 5 THEN 0 \
WHEN 3+4==7 THEN 1 \
ELSE 2 \
END \
AS result;
+--------+
| result |
+--------+
| 1 |
+--------+
nebula> MATCH (v:player) WHERE v.age > 30 \
RETURN v.name AS Name, \
CASE \
WHEN v.name STARTS WITH "T" THEN "Yes" \
ELSE "No" \
END \
AS Starts_with_T;
+---------------------+---------------+
| Name | Starts_with_T |
+---------------------+---------------+
| "Tim" | "Yes" |
+---------------------+---------------+
| "LaMarcus Aldridge" | "No" |
+---------------------+---------------+
| "Tony Parker" | "Yes" |
+---------------------+---------------+
简单形式和通用形式的区别
为了避免误用简单形式和通用形式,用户需要了解它们的差异。请参见如下示例:
nebula> GO FROM "player100" OVER follow \
YIELD $$.player.name AS Name, $$.player.age AS Age, \
CASE $$.player.age \
WHEN $$.player.age > 35 THEN "Yes" \
ELSE "No" \
END \
AS Age_above_35;
+---------------------+-----+--------------+
| Name | Age | Age_above_35 |
+---------------------+-----+--------------+
| "Tony Parker" | 36 | "No" |
+---------------------+-----+--------------+
| "LaMarcus Aldridge" | 33 | "No" |
+---------------------+-----+--------------+
示例本意为当玩家年龄大于35时输出Yes
。但是查看输出结果,年龄为36时输出的却是No
。
这是因为查询使用了简单形式的CASE
表达式,比较对象是.player.age
和.player.age > 35
。当年龄为36时:
$$.player.age
的值为36
,数据类型为int。$$.player.age > 35
的值为true
,数据类型为boolean。
这两种数据类型无法匹配,不满足条件,因此返回No
。