TTLGraph
TTL(Time To Live)指定属性的存活时间,超时后,该属性就会过期。
openCypher兼容性Graph
本文操作仅适用于原生nGQL。
注意事项Graph
- 不能修改带有TTL选项的属性的Schema。
-
TTL 和 INDEX 共存问题:
- 如果已有 INDEX:不能再设置 TTL,即使在没有 INDEX 的属性上设置 TTL 也不行。
- 如果已有 TTL:可以再添加 INDEX。
属性过期Graph
点属性过期Graph
点属性过期有如下影响:
- 如果一个点仅有一个Tag,点上的一个属性过期,点也会过期。
- 如果一个点有多个Tag,点上的一个属性过期,和该属性相同Tag的其他属性也会过期,但是点不会过期,点上其他Tag的属性保持不变。
边属性过期Graph
因为一条边仅有一个Edge type,边上的一个属性过期,边也会过期。
过期处理Graph
属性过期后,对应的过期数据仍然存储在硬盘上,但是查询时会过滤过期数据。
NebulaGraph自动删除过期数据后,会在下一次Graph过程中回收硬盘空间。
Note
如果Graph,上一次Compaction之后的过期数据将可以被查询到。
TTL选项Graph
nGQL支持的TTL选项如下。
选项 | 说明 |
---|---|
ttl_col |
指定要设置存活时间的属性。属性的数据类型必须是int 或者timestamp 。 |
ttl_duration |
指定时间戳差值,单位:秒。时间戳差值必须为64位非负整数。属性值和时间戳差值之和如果小于当前时间戳,属性就会过期。如果ttl_duration 为0 ,属性永不过期。 |
使用TTL选项Graph
Tag或Edge type已存在Graph
如果Tag和Edge type已经创建,请使用ALTER
语句更新Tag或Edge type。
# 创建Tag。
nebula> CREATE TAG t1 (a timestamp);
# ALTER修改Tag,添加TTL选项。
nebula> ALTER TAG t1 ttl_col = "a", ttl_duration = 5;
# 插入点,插入后5秒过期。
nebula> INSERT VERTEX t1(a) values "101":(now());
Tag或Edge type不存在Graph
创建Tag或Edge type时可以同时设置TTL选项。详情请参见Graph。
# 创建Tag并设置TTL选项。
nebula> CREATE TAG t2(a int, b int, c string) ttl_duration= 100, ttl_col = "a";
# 插入点。过期时间戳为1612778164774(1612778164674 + 100)。
nebula> INSERT VERTEX t2(a, b, c) values "102":(1612778164674, 30, "Hello");
删除存活时间Graph
删除存活时间可以使用如下几种方法:
- 删除设置存活时间的属性。
nebula> ALTER TAG t1 DROP (a);
- 设置
ttl_col
为空字符串。nebula> ALTER TAG t1 ttl_col = "";
- 设置
ttl_duration
为0
。本操作可以保留TTL选项,属性永不过期,且属性的Schema无法修改。nebula> ALTER TAG t1 ttl_duration = 0;
最后更新: September 18, 2021