修改 Edge

  1. ALTER EDGE <edge_name>
  2. <alter_definition> [, alter_definition] ...]
  3. [ttl_definition [, ttl_definition] ... ]
  4. <alter_definition>::=
  5. ADD (prop_name data_type)
  6. | DROP (prop_name)
  7. | CHANGE (prop_name data_type)
  8. ttl_definition::=
  9. TTL_DURATION = ttl_duration, TTL_COL = prop_name

ALTER EDGE 语句可改变边的结构,例如,可以添加或删除属性,更改已有属性的类型,也可将属性设置为 TTL(生存时间),或更改 TTL 时间。

注意: 修改边结构时,Nebula Graph 将自动检测是否存在索引。修改时需要两步判断。首先,判断这个边是否关联索引。其次,检查所有关联的索引,判断待删除或更改的 column item 是否存在于索引的 column 中,如果存在则拒绝修改。如果不存在,即使有关联的索引也允许修改。

请参考索引文档了解索引详情。

一个 ALTER 语句允许使用多个 ADDDROPCHANGE 语句,语句之间需用逗号隔开。但是不要在一个语句中添加,删除或更改相同的属性。如果必须进行此操作,请将其作为 ALTER 语句的子语句。

  1. nebula> CREATE EDGE e1 (prop3 int, prop4 int, prop5 int);
  2. nebula> ALTER EDGE e1 ADD (prop1 int, prop2 string), /* 添加 prop1 */
  3. CHANGE (prop3 string), /* 将 prop3 类型更改为字符 */
  4. DROP (prop4, prop5); /* 删除 prop4 和 prop5 */
  5. nebula> ALTER EDGE e1 TTL_DURATION = 2, TTL_COL = prop1;

注意 TTL_COL 仅支持 INT 和 TIMESTAMP 类型。