字符串

Nebula Graph支持定长字符串和变长字符串。

声明与表示方式

nGQL中的字符串声明方式如下:

  • 使用关键字STRING声明变长字符串。
  • 使用关键字FIXED_STRING(<length>)声明定长字符串,<length>为字符串长度,例如FIXED_STRING(32)

字符串的表示方式为用双引号或单引号包裹,例如"Hello, Cooper"'Hello, Cooper'

字符串读写

nGQL支持以如下方式使用字符串:

  • VID的数据类型定义为定长字符串。
  • 将变长字符串设置为Schema名称,包括图空间、Tag、Edge type和属性的名称。
  • 将属性值的数据类型定义为定长或变长字符串。

例如:

  • 将属性值的类型定义为定长字符串

    1. nebula> CREATE TAG t1 (p1 FIXED_STRING(10));
  • 将属性值的类型定义为变长字符串

    1. nebula> CREATE TAG t2 (p2 STRING);

如果尝试写入的定长字符串超出长度限制:

  • 当该定长字符串为属性值时,写入会成功,Nebula Graph将截断字符串,仅存入符合长度限制的部分。
  • 当该定长字符串为VID时,写入会失败,Nebula Graph将报错。

转义字符

字符串中不支持直接换行,可以使用转义字符实现,例如:

  • "\n\t\r\b\f"

  • "\110ello world"

OpenCypher兼容性

openCypher、Cypher和nGQL之间有一些细微区别,例如下面openCypher的示例,不能将单引号替换为双引号。

  1. # File: Literals.feature
  2. Feature: Literals
  3. Background:
  4. Given any graph
  5. Scenario: Return a single-quoted string
  6. When executing query:
  7. """
  8. RETURN '' AS literal
  9. """
  10. Then the result should be, in any order:
  11. | literal |
  12. | '' | # Note: it should return single-quotes as openCypher required.
  13. And no side effects

Cypher的返回结果同时支持单引号和双引号,nGQL遵循Cypher的方式。

  1. nebula > YIELD '' AS quote1, "" AS quote2, "'" AS quote3, '"' AS quote4
  2. +--------+--------+--------+--------+
  3. | quote1 | quote2 | quote3 | quote4 |
  4. +--------+--------+--------+--------+
  5. | "" | "" | "'" | """ |
  6. +--------+--------+--------+--------+

最后更新: August 26, 2021