跳转至

INSERT VERTEX 语法Graph

INSERT VERTEX <tag_name> [, <tag_name>, ...] (prop_name_list[, prop_name_list])
     {VALUES | VALUE} VID: (prop_value_list[, prop_value_list])

prop_name_list:
  [prop_name [, prop_name] ...]

prop_value_list:
  [prop_value [, prop_value] ...]

INSERT VERTEX 可向 NebulaGraph 插入节点。

  • tag_name 表示标签(节点类型),在进行 INSERT VERTEX 操作前需创建好。
  • prop_name_list 指定标签的属性列表。
  • VID 表示点 ID。每个图空间中的 VID 必须唯一。目前的排序依据为“二进制编码顺序“:即 0, 1, 2, ... 9223372036854775807, -9223372036854775808, -9223372036854775807, ..., -1。VID 支持手动指定 ID 或使用 hash() 函数生成。
  • prop_value_list 须根据 prop_name_list 列出属性值,如无匹配类型,则返回错误。

示例Graph

nebula> CREATE TAG t1();                  -- 创建空属性标签 t1
nebula> INSERT VERTEX t1 () VALUES 10:();    -- 插入空属性点 10
nebula> CREATE TAG t2 (name string, age int);                -- 创建有两种属性的标签 t2
nebula> INSERT VERTEX t2 (name, age) VALUES 11:("n1", 12);     -- 插入有两种属性的点 11
nebula> INSERT VERTEX t2 (name, age) VALUES 12:("n1", "a13");  -- 错误操作,"a13" 不是 int 类型
nebula> INSERT VERTEX t2 (name, age) VALUES 13:("n3", 12), 14:("n4", 8);    -- 插入两个点
nebula> CREATE TAG t1(i1 int);
nebula> CREATE TAG t2(s2 string);
nebula> INSERT VERTEX  t1 (i1), t2(s2) VALUES 21: (321, "hello");   -- 插入有两个标签的点 21

同一节点可被多次插入或写入,读取时以最后一次插入为准。

-- 为点 11 多次插入新值
nebula> INSERT VERTEX t2 (name, age) VALUES 11:("n2", 13);
nebula> INSERT VERTEX t2 (name, age) VALUES 11:("n3", 14);
nebula> INSERT VERTEX t2 (name, age) VALUES 11:("n4", 15);  -- 读取最后插入的值

最后更新: August 11, 2020