1

我对 Neptune 使用Gremlin-scala 3.4.1.5,我无法使用带有 List 或 Set 的案例类添加顶点,就像这样。添加顶点似乎在不存在时起作用

//connection
Cluster.build()
      .addContactPoint(endpoint)
      .serializer(new GraphSONMessageSerializerV3d0())
      .port(port)
      .create()

val g = EmptyGraph.instance.asScala().configure(_.withRemote(DriverRemoteConnection.using(cluster)))

// adding vertex

case class Person(name: String, friends: Seq[String])
case class Person(name: String, friends: Set[String]) // also does not work
g + Person

堆栈跟踪

org.apache.tinkerpop.gremlin.driver.exception.ResponseException: {"requestId":-087f-4868-b4b7-","code":"UnsupportedOperationException","detailedMessage":"Unsupported property value type: java.util.LinkedHashMap"}
java.util.concurrent.CompletionException: org.apache.tinkerpop.gremlin.driver.exception.ResponseException: {"requestId":"-087f-4868-b4b7-","code":"UnsupportedOperationException","detailedMessage":"Unsupported property value type: java.util.LinkedHashMap"}
    at java.util.concurrent.CompletableFuture.reportJoin(CompletableFuture.java:375)
    at java.util.concurrent.CompletableFuture.join(CompletableFuture.java:1934)
    at org.apache.tinkerpop.gremlin.driver.ResultSet.one(ResultSet.java:119)
    at org.apache.tinkerpop.gremlin.driver.ResultSet$1.hasNext(ResultSet.java:171)
    at org.apache.tinkerpop.gremlin.driver.ResultSet$1.next(ResultSet.java:178)
    at org.apache.tinkerpop.gremlin.driver.ResultSet$1.next(ResultSet.java:165)
    at org.apache.tinkerpop.gremlin.driver.remote.DriverRemoteTraversal$TraverserIterator.next(DriverRemoteTraversal.java:140)
    at org.apache.tinkerpop.gremlin.driver.remote.DriverRemoteTraversal$TraverserIterator.next(DriverRemoteTraversal.java:125)
    at org.apache.tinkerpop.gremlin.driver.remote.DriverRemoteTraversal.nextTraverser(DriverRemoteTraversal.java:106)
4

3 回答 3

0

Neptune 不支持将 List 作为属性类型 [1]。如果需要有序列表,一种方法是将其序列化为单个属性(例如:列表的 json 字符串)。它确实需要应用层中的一些逻辑来正确读回它。做列表的另一种常见方法是将列表项单独建模为顶点,并将它们建模为图中的边。

例如:不要拥有地址列表的属性,而是将地址设为顶点标签,并从您的人到地址 1 到地址 2 的边。如果您预计列表会发生突变,则此选项会更好。

https://docs.aws.amazon.com/neptune/latest/userguide/access-graph-gremlin-differences.html

更新

接受这个作为答案,因为这就是我最终使用的。我只想澄清几件事。

在使用 Gremlin property() 步骤等时,Neptune 支持 Single 和 Set 基数属性。

我在Gremlin-scala中打开了一个问题,因为我认为应该支持原生 TinkerPop 基数ListSet. List今天在 Neptune 中会失败,但这很好,因为用户可以切换到Set它是否适用于他们的用例并且这会奏效。

于 2019-06-26T23:43:30.697 回答
0

回覆Unsupported property value type: java.util.LinkedHashMap

我没有可用的海王星设置,但普通的 scalaList可能会工作。如果没有,这是宏中的相关部分:

https://github.com/mpollmeier/gremlin-scala/blob/2e32ae0/macros/src/main/scala/gremlin/scala/Marshallable.scala#L178-L179

https://github.com/mpollmeier/gremlin-scala/blob/2e32ae0/macros/src/main/scala/gremlin/scala/Marshallable.scala#L110-L120

于 2019-06-15T22:34:45.230 回答
0

根据本文档,我相信 Neptune 可能不支持顶点上的列表属性:https ://docs.aws.amazon.com/neptune/latest/userguide/access-graph-gremlin-differences.html

要对此进行测试,您可以尝试针对 gremlin-server 或其他一些实现运行相同的代码

于 2019-06-18T16:58:30.773 回答