概述
使用语句insert()可以向图集的一个schema插入新的点和边。
// 插入点
insert().into(<schema>).nodes([
  {<property1?>: <value1?>, <property2?>: <value2?>, ...},
  {<property1?>: <value1?>, <property2?>: <value2?>, ...},
  ...
])
// 插入边
insert().into(<schema>).edges([
  {_from: <fromValue>, _to: <toValue>, <property1?>: <value1?>, <property2?>: <value2?>, ...},
  {_from: <fromValue>, _to: <toValue>, <property1?>: <value1?>, <property2?>: <value2?>, ...},
  ...
])
| 方法 | 参数 | 描述 | 
|---|---|---|
| into() | <schema> | 指定点schema或边schema,如 @user | 
| nodes()或edges() | 属性规范列表 | 将一或多个点或边插入指定schema,其中每个属性规范需用 {}包裹 | 
属性规范列表中出现的每个属性都会被赋予给定的值,而缺失的自定义属性将默认赋值为null。
请注意:
- 点的_id值若未指定,将由系统自动生成;也可根据需要为其指定唯一值。
- 点和边的_uuid值由系统自动生成,不允许指定。
- 必须提供边属性_from和_to以指明边的起点和终点。
Schema-Free图中的属性
在Schema-Free图中,你可以直接插入点和边,系统会自动创建相应的Schema和属性。创建属性时,它的值类型是根据提供的第一个值推断而来的,示例如下:
| 示例值 | 描述 | 推断的属性值类型 | 
|---|---|---|
| -20,1315 | -9,223,372,036,854,775,808到9,223,372,036,854,775,806范围内的整数 | INT64 | 
| 100000000000000001 | 9,223,372,036,854,775,807到18,446,744,073,709,551,614范围内的整数 | UINT64 | 
| 18.25 | 最多包含15位有效数字的小数 | DOUBLE | 
| "graph database" | 最大长度为 60,000字节的字符串 | STRING | 
| "graph database is ..." | 长度超过 60,000字节的字符串 | TEXT | 
| date("1993-05-09") | date()函数返回值 | DATE | 
| local_datetime("1993-05-09 03:02:11") | local_datetime()函数返回值 | LOCAL DATETIME | 
| local_time("03:02:11") | local_time()函数返回值 | LOCAL TIME | 
| zoned_datetime("1993-05-09T03:02:11-0600") | zaoned_datetime()函数返回值 | ZONED DATETIME | 
| zoned_time("03:02:11-06:00") | zoned_time()函数返回值 | ZONED TIME | 
| TRUE,FALSE | 布尔值 | BOOL | 
| point({latitude:39.9, longitude:116.3}) | point()函数返回值 | POINT | 
| point3d({x:10, y:3.2, z:5}) | point3d()函数返回值 | POINT3D | 
| ["tennis", "football", "swimming"] | 构建的列表 | LIST | 
示例图集

在一个空图集中,逐行运行以下UQL语句,创建示例图集:
create().node_schema("user").edge_schema("follow")
create().node_property(@user, "name").node_property(@user, "age", int32).node_property(@user, "location", point).node_property(@user, "isBlocked", bool).node_property(@user, "permissionCodes", "set(uint32)").edge_property(@follow, "time", datetime)
insert().into(@user).nodes([{_id:"U001", name:"Jason", age:30}, {_id:"U002", name:"Tim"}, {_id:"U003", name:"Grace", age:25}, {_id:"U004", name:"Ted", age:26}])
insert().into(@follow).edges([{_from:"U004", _to:"U001", time:"2021-9-10"}, {_from:"U003", _to:"U001", time:"2020-3-12"}, {_from:"U004", _to:"U002", time:"2023-7-30"}])
插入单个点/边
插入一个@user点:
insert().into(@user).nodes({_id: "U005", name: "Alice"})
插入一条@follow边:
insert().into(@follow).edges({_from: "U002", _to: "U001", time: "2023-8-9"})
插入单个点或边时,可省略
nodes()或edges()中的外层方括号[]。
插入多个点/边
插入三个@user点:
insert().into(@user).nodes([
  {_id: "U006", name: "Lee", age: 12},
  {name: "Alex"},
  {}
])
插入两条@follow边:
insert().into(@follow).edges([
  {_from: "U001", _to: "U002"},
  {_from: "U004", _to: "U003", time: "2023-9-10"}
])
返回插入的数据
插入两条@follow边并返回插入边的所有信息:
insert().into(@follow).edges([
  {_from: "U001", _to: "U004"},
  {_from: "U001", _to: "U003", time: "2022-2-7"}
]) as e
return e{*}
结果:e
| _uuid | _from | _to | _from_uuid | _to_uuid | schema | values | 
|---|---|---|---|---|---|---|
| Sys-gen | U001 | U004 | UUID of U001 | UUID of U004 | follow | {time: null} | 
| Sys-gen | U001 | U003 | UUID of U001 | UUID of U003 | follow | {time: "2022-02-07 00:00:00"} | 
插入布尔类型值
bool类型的属性只接受1(或true)或0(或false)两个值。
如果赋除
0以外的正整数,都自动转换成1;赋其他值的结果无法预期。
插入一个@user点,其属性isBlocked的数据类型为bool:
insert().into(@user).nodes({isBlocked: 0})
插入Point类型值
使用point()函数为point类型属性指定属性值。例如,插入一个@user点,其属性location的数据类型为point:
insert().into(@user).nodes([
  {location: point({latitude: 132.1, longitude: -1.5})}
]) as n
return n.location
结果:
| n.location | 
|---|
| POINT(132.1 -1.5) | 
使用point3d()函数为point3d类型属性指定属性值。例如,插入一个@city点,其属性landmark的数据类型为point3d:
insert().into(@city).nodes([
  {landmark: point3d({x: 10, y: 3.2, z: 5})}
]) as n
return n.landmark
结果:
| n.landmark | 
|---|
| POINT3D(10 3.2 5) | 
插入Record类型值
插入一个@product点,其属性specs的数据类型为record:
insert().into(@product).nodes([
  {specs: {weight: "2kg", color: "red", warranty: "1y"}}
])
插入Blob类型值
插入一个@user点,其属性avatar的数据类型为blob:
with "" as base64_string
insert().into(@user).nodes([
  {avatar: base64_string}
])
插入列表类型值
插入一个@user点,其属性interests的数据类型为string[]:
insert().into(@user).nodes([
  {interests: ["violin", "tennis", "movie"]}
])
插入集合类型值
插入一个@user点,其属性permissionCodes的数据类型为set(uint32):
insert().into(@user).nodes([
  {permissionCodes: [1002, 1002, 1003, 1004]}
]) as n
return n.permissionCodes
结果:
| n.permissionCodes | 
|---|
| [1003,1004,1002] | 
集合内的元素值会自动去重。
