我有以下查询,它与 TinkerGraph、JanusGraph 和 Neo4j-Gremlin 没有任何问题:
g.V().has('Account','address','0x0').
out('sent').has('eventName','Transfer').as('t1').
out('received_by').has('type','EOA').has('status','Active').as('a2').
out('sent').has('eventName','Transfer').as('t2').
where('t1',eq('t2')).by('address').
where('t1',eq('t2')).by('amount').
out('received_by').has('type','EOA').has('status','Active').as('a3').
select('a3','a2').
by('address').
group().
by('a3').
by('a2').
unfold().
where(select(values).limit(local,2).count(local).is(gte(2).and(lte(1000))))
但是使用 DataStax Graph 我收到以下错误:
java.util.LinkedHashMap cannot be cast to org.apache.tinkerpop.gremlin.structure.Element
我知道问题出在选择之后,但我无法弄清楚哪一点真的失败了。任何想法都会有所帮助。谢谢。
DataStax Graph 6.8.1 使用 TinkerPop 3.4.5 的早期版本。该版本不包含完整的版本功能,允许by(String)
工作在Map
。您应该能够将遍历重写为:
g.V().has('Account','address','0x0').
out('sent').has('eventName','Transfer').as('t1').
out('received_by').has('type','EOA').has('status','Active').as('a2').
out('sent').has('eventName','Transfer').as('t2').
where('t1',eq('t2')).by('address').
where('t1',eq('t2')).by('amount').
out('received_by').has('type','EOA').has('status','Active').as('a3').
select('a3','a2').
by('address').
group().
by(select('a3')).
by(select('a2').fold()).
unfold().
where(select(values).limit(local,2).count(local).is(gte(2).and(lte(1000))))
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句