字符串Graph
NebulaGraph支持定长字符串和变长字符串。
声明与表示方式Graph
nGQL中的字符串声明方式如下:
- 使用关键字
STRING
声明变长字符串。 - 使用关键字
FIXED_STRING(<length>)
声明定长字符串,<length>
为字符串长度,例如FIXED_STRING(32)
。
字符串的表示方式为用双引号或单引号包裹,例如"Hello, Cooper"
或'Hello, Cooper'
。
字符串读写Graph
nGQL支持以如下方式使用字符串:
- 将Graph的数据类型定义为定长字符串。
- 将变长字符串设置为Schema名称,包括图空间、Tag、Edge type和属性的名称。
- 将属性值的数据类型定义为定长或变长字符串。
例如:
- 将属性值的类型定义为定长字符串
nebula> CREATE TAG t1 (p1 FIXED_STRING(10));
- 将属性值的类型定义为变长字符串
nebula> CREATE TAG t2 (p2 STRING);
如果尝试写入的定长字符串超出长度限制:
- 当该定长字符串为属性值时,写入会成功,NebulaGraph将截断字符串,仅存入符合长度限制的部分。
- 当该定长字符串为VID时,写入会失败,NebulaGraph将报错。
转义字符Graph
字符串中不支持直接换行,可以使用转义字符实现,例如:
"\n\t\r\b\f"
"\110ello world"
OpenCypher兼容性Graph
openCypher、Cypher和nGQL之间有一些细微区别,例如下面openCypher的示例,不能将单引号替换为双引号。
# File: Literals.feature
Feature: Literals
Background:
Given any graph
Scenario: Return a single-quoted string
When executing query:
"""
RETURN '' AS literal
"""
Then the result should be, in any order:
| literal |
| '' | # Note: it should return single-quotes as openCypher required.
And no side effects
Cypher的返回结果同时支持单引号和双引号,nGQL遵循Cypher的方式。
nebula > YIELD '' AS quote1, "" AS quote2, "'" AS quote3, '"' AS quote4
+--------+--------+--------+--------+
| quote1 | quote2 | quote3 | quote4 |
+--------+--------+--------+--------+
| "" | "" | "'" | """ |
+--------+--------+--------+--------+
最后更新: August 26, 2021