Dan*_*son 2 azure graph-databases gremlin azure-cosmosdb azure-cosmosdb-gremlinapi
我试图在 cosmos db 中创建一个 gremlin 查询,其中所有顶点的属性都被展平。
我取得的最好成就是使用“valueMap”
询问
g.V('12345').valueMap(true))
Run Code Online (Sandbox Code Playgroud)
结果
{
"id": "12345",
"label": "product",
"name": [
"product name"
],
"description": [
"productdescription"
],
}
Run Code Online (Sandbox Code Playgroud)
我想要实现的目标
{
"id": "12345",
"label": "product",
"name": "product name",
"description": "productdescription"
}
Run Code Online (Sandbox Code Playgroud)
看起来 elementMap 是正确的方法,但 Cosmos Db 似乎不支持它。
是否有不支持此功能的原因或是否存在类似的解决方案?
CosmosDB 在支持 Gremlin 语言的各个方面往往有点落后。有解决方法。之前的elementMap()典型模式是使用by()调制器来valueMap()添加unfold()列表:
gremlin> g.V().valueMap(true).by(unfold())
==>[id:1,label:person,name:marko,age:29]
==>[id:2,label:person,name:vadas,age:27]
==>[id:3,label:software,name:lop,lang:java]
==>[id:4,label:person,name:josh,age:32]
==>[id:5,label:software,name:ripple,lang:java]
==>[id:6,label:person,name:peter,age:35]
Run Code Online (Sandbox Code Playgroud)
我不知道 CosmosDB 是否支持该特定by()调制器。如果没有的话,它就会变得有点难看:
gremlin> g.V().map(valueMap(true).unfold().group().by(keys).by(select(values).unfold()))
==>[id:1,label:person,name:marko,age:29]
==>[id:2,label:person,name:vadas,age:27]
==>[id:3,label:software,name:lop,lang:java]
==>[id:4,label:person,name:josh,age:32]
==>[id:5,label:software,name:ripple,lang:java]
==>[id:6,label:person,name:peter,age:35]
Run Code Online (Sandbox Code Playgroud)
也许:
gremlin> g.V().map(valueMap(true).unfold().group().by(keys).by(select(values).limit(local,1)))
==>[id:1,label:person,name:marko,age:29]
==>[id:2,label:person,name:vadas,age:27]
==>[id:3,label:software,name:lop,lang:java]
==>[id:4,label:person,name:josh,age:32]
==>[id:5,label:software,name:ripple,lang:java]
==>[id:6,label:person,name:peter,age:35]
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
616 次 |
| 最近记录: |