概述
INSERT语句通过点模式和边模式向图中插入新的点和边。
与图模式匹配不同,INSERT语句中的点和边模式支持变量声明、标签/Schema表达式和属性规范,但不允许使用WHERE子句。此外,INSERT仅支持最基本的点与边模式的连接方式,并且必须指定边方向。
嬴图支持类型图和开放图,向这两种图中插入数据的语法类似,但要求有所不同。
类型图
在类型图中,插入的点和边必须满足其图类型。如果点、边指定的Schema和属性尚未定义,则无法插入。
在类型图中,每个点或边必须且只能指定一个Schema。所有的属性赋值都会根据指定的值类型进行校验;未赋值属性的默认值为null。
创建一个类型图;
CREATE GRAPH g1 {
NODE User ({name STRING, gender STRING}),
NODE Club ({since INT32}),
EDGE Follows ()-[{createdOn DATE}]->(),
EDGE Joins ()-[{memberNo UINT32}]->()
}
开放图
在开放图中,你可以直接插入点和边,系统会自动创建相应的标签和属性。
在开放图中,可以为每个点或边指定零个、一个或多个标签,每个点或边单独关联一组属性。
创建一个开放图:
CREATE GRAPH g2 ANY
插入点
使用点模式插入点。
插入一个User点:
INSERT (:User {name: "claire", gender: "female"})
插入多个点并返回它们:
INSERT (n1:User {_id: "U2", name: "Quasar92"}),
(n2:Club {_id: "C1"}),
(n3:Club)
RETURN n1, n2, n3
在开放图中,你可以给一个点指定多个标签:
INSERT (n:Person&Employee {name: "Bob"})
RETURN n
插入边
使用边模式插入边,边模式两端连接点模式,并包含方向以指示起点和终点。
插入两个User点,并在它们中间插入一条Follows边:
INSERT (:User {name: 'rowlock'})-[:Follows {since: date('2024-01-05')}]->(:User {name: 'Brainy', gender: 'male'})
如果要将边插入到已存在的两点之间,首先使用MATCH语句获取点:
MATCH (n1:User {name: 'claire'}), (n2:Club {_id: 'C1'})
INSERT (n1)-[e:Joins {fee: 1200}]->(n2)
RETURN e
插入一条Joins边,起点是一个已存在的User点,终点是新插入的Club点:
MATCH (user:User {name: 'Quasar92'})
INSERT (user)-[:Joins]->(:Club {_id: "C2"})
插入图

上图可视为两条在Club点相交的路径:
INSERT (:User {name: 'waveBliss'})-[:Joins]->(c:Club {_id: 'C3'}),
(:User {name: 'bella'})-[:Joins]->(c)<-[:Joins]-(:User {name: 'Roose'})
或者,你也可以单独插入图中的点和边:
INSERT (waveBliss:User {name: 'waveBliss'}),
(bella:User {name: 'bella'}),
(Roose:User {name: 'Roose'}),
(C3:Club {_id: 'C3'}),
(waveBliss)-[:Joins]->(C3),
(bella)-[:Joins]->(C3),
(Roose)-[:Joins]->(C3)
属性值示例
嬴图支持多种属性类型。查看完整列表
以下是不同类型属性值的示例。这些示例假设在类型图中使用,其中属性具有明确的值类型定义。在开放图中,属性值类型也是开放的,但这些示例仍可作为赋值的参考。
数值类属性
数值类属性值类型包括INT(INT32)、UINT(UINT32)、INT64、UINT64、FLOAT、DOUBLE和DECIMAL(<precision>, <scale>)。
// age is UINT32, weight is DECIMAL(10,2)
INSERT (:Person {age: 34, weight: 60.3})
文本类属性
文本类属性值类型包括STRING和TEXT。
// name is STRING
INSERT (:Person {name: "John Doe"})
时间点类属性
时间点类属性值类型包括DATE、LOCAL DATETIME、LOCAL TIME、ZONED DATETIME、ZONED TIME、TIMESTAMP和DATETIME。
// register is ZONED DATETIME, lastLogin is timestamp
INSERT (:Person {
register: zoned_datetime("2025-01-01 12:20:02+0200"),
lastLogin: 1762338059
})
时间段类属性
时间段类属性值类型包括DURATION(YEAR TO MONTH)和DURATION(DAY TO SECOND)。
// ativeDuration is DURATION(DAY TO SECOND)
INSERT (:Person {ativeDuration: "P526DT23H14M8S"})
布尔类属性
布尔类属性值类型包括BOOL。
// isBlocked is BOOL
INSERT (:Person {isBlocked: FALSE})
空间类属性
空间类属性值类型包括POINT和POINT3D。
// location is POINT, PoI is POINT3D
INSERT (:Person {
location: POINT({latitude: 22.3, longitude: 125.6}),
PoI: POINT3D({x: 10, y: 3.4, z: 6.2})
})
记录类属性
记录类属性值类型包括RECORD。
// bodyInfo is RECORD
INSERT (:Person {
bodyInfo: {height: 175, weight: 68, bmi: 22.2, hairColor: "brown", bloodTyle: "O"}
})
二进制类属性
二进制类属性值类型包括BLOB。
// avatar is BLOB
INSERT (:Person {
avatar: ""
})
列表类属性
列表类属性值类型包括LIST<subType>。
// tags is LIST<STRING>
INSERT (:Person {tags: ["IT", "happy", "geek"]})