Как объединить узлы на выделение в TinkerPop3? - PullRequest
0 голосов
/ 10 сентября 2018

Я работаю с графиком Apache Gremlin и TinkerPop3. Есть два узла

<!-- # parentNode with properties # -->
g.addV('Location')
.property('id', 'fb864e1f-a2e0-4c02-b891-2c0713b29751')
.property('name', 'BananaShop')
.property('description', 'Ipsum dolor sit ...')
.property('fuu', 'abc')
.property('bar', 'xyz')
.addE('FR-FR').to(g.V('b3bd8a03-531f-4f7f-b355-32954b03fd21')) 

, а также

<!-- # childNode with translations only # -->
g.addV('Localized')
.property('id', 'b3bd8a03-531f-4f7f-b355-32954b03fd21')
.property('name', 'FR.BananaShop')
.property('description', 'Et ea rebum ...')

мой запрос:

g.V().has("Name","BananaShop").as("a").out("FR-FR").as("b").select("a","b")   

Результат в порядке. Я получил оба узла со всеми свойствами! Но меня интересует только один результат со свойствами родительского узла и переводами дочернего узла. если у меня нет подходящего потомка с переводами, выберите «имя» и «описание» родителя.

{
 id : ...,
 name : "FR-FR",         // childnode data
 description : "FR-FR",  // childnode data
 fuu : "...",
 bar : "..."
}

Как мне изменить свой запрос для этого?

Ответы [ 2 ]

0 голосов
/ 12 сентября 2018

Если вы хотите получить таблицу значений с исходными значениями свойств, перезаписанными локализованными свойствами (если они существуют):

g.V().has('name','BananaShop').as('b').
  coalesce(out('FR-FR'), identity()).valueMap().as('l').
  select('b').properties().as('p').
  group().
    by(key()).
    by(coalesce(select('l').select(select('p').key()).unfold(), value()).fold())

Примеры

Существующий перевод

gremlin> g.V().has('name','BananaShop').as('b').
......1>   coalesce(out('FR-FR'), identity()).valueMap().as('l').
......2>   select('b').properties().as('p').
......3>   group().
......4>     by(key()).
......5>     by(coalesce(select('l').select(select('p').key()).unfold(), value()).fold()).
......6>   unfold()
==>bar=[xyz]
==>fuu=[abc]
==>name=[FR.BananaShop]
==>description=[Et ea rebum ...]
==>id=[b3bd8a03-531f-4f7f-b355-32954b03fd21]

Несуществующий перевод

gremlin> g.V().has('name','BananaShop').as('b').
......1>   coalesce(out('DE-DE'), identity()).valueMap().as('l').
......2>   select('b').properties().as('p').
......3>   group().
......4>     by(key()).
......5>     by(coalesce(select('l').select(select('p').key()).unfold(), value()).fold()).
......6>   unfold()
==>bar=[xyz]
==>fuu=[abc]
==>name=[BananaShop]
==>description=[Ipsum dolor sit ...]
==>id=[fb864e1f-a2e0-4c02-b891-2c0713b29751]
0 голосов
/ 10 сентября 2018

Я бы использовал project() в этом случае:

gremlin> g.V().has('name','BananaShop').
......1>   project('id','name','description','fuu','bar').
......2>     by('id').
......3>     by(out('FR-FR').values('name')).
......4>     by(out('FR-FR').values('description')).
......5>     by('fuu').
......6>     by('bar')
==>[id:fb864e1f-a2e0-4c02-b891-2c0713b29751,name:FR.BananaShop,description:Et ea rebum ...,fuu:abc,bar:xyz]

Вы проходите out() дважды, хотя, делая это. Если это дорого в CosmosDB, вы можете изменить свой формат на что-то вроде:

gremlin> g.V().has('name','BananaShop').
......1>   project('id','child','fuu','bar').
......2>     by('id').
......3>     by(out('FR-FR').project('name','description').by('name').by('description')).
......4>     by('fuu').
......5>     by('bar')
==>[id:fb864e1f-a2e0-4c02-b891-2c0713b29751,child:[name:FR.BananaShop,description:Et ea rebum ...],fuu:abc,bar:xyz]
...