JanusGraph入坑笔记(四)- TraversalStrategy

本文介绍了JanusGraph的TraversalStrategy的五种类型:DecorationStrategy、OptimizationStrategy、ProviderOptimizationStrategy、FinalizationStrategy和VerificationStrategy,以及它们的作用和排序规则。TraversalStrategy用于优化和调整图遍历,包括前置和后置策略的执行顺序,通过TraversalStrategies.sortStrategies()进行t-sort排序来确定策略的执行顺序。
摘要由CSDN通过智能技术生成

目录

一、TraversalStrategy类型

(一)DecorationStrategy

 (二)OptimizationStrategy

(三)ProviderOptimizationStrategy

(四)FinalizationStrategy 

(五)VerificationStrategy

二、前置和后置条件

(一)前置策略

(二)后置策略

三、策略排序规则

(一)代码分析

(二)t-sort排序


一、TraversalStrategy类型

上一篇提到了StandardJanusGraph在实例话之前就加入了六个strategies,但是他们是同一种。下面我们看看五类strategy分别是什么。

(一)DecorationStrategy

Implemented by strategies that adds "application logic" to the traversal

为traversal加入“应用策略”,具体什么事应用策略,可以看到它的实现类中是一些关于事务、链接、ID生成等策略。

 (二)OptimizationStrategy

Implemented by strategies that rewrite the traversal to be more efficient, but with the same semantics (e.g. CountStrategy). During a re-write ONLY TinkerPop steps should be used. For strategies that utilize provider specific steps, use TraversalStrategy.ProviderOptimizationStrategy.

只有属于TinkerPop的step类型可以在这里被修改,但是只限于在保证语义(姑且认为是gremlin语句)的情况下提高效率。对于特定步骤(自定义step),使用下面的的 TraversalStrategy.ProviderOptimizationStrategy。

(三)ProviderOptimizationStrategy

Implemented by strategies that rewrite the traversal to be more efficient, but with the same semantics. This is for graph system/language/driver providers that want to rewrite a traversal using provider specific steps.

同样是保证语义的情况下,让不同的图系统,语言,驱动拥有自定义step的能力。在上一篇中加入的六个strategy就是JanusGraph用这个接口对TingkerPop传过来的traversal做修改。

(四)FinalizationStrategy 

Implemented by strategies that do final behaviors that require a fully compiled traversal to work (e.g. ProfileStrategy).

为traversal增加一个最终行为࿰

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值