Вы можете добавлять/обновлять свойства ребра, но с графовыми базами данных вы не можете обновлять атрибуты, которые делают его ребром, т. е. вы не можете обновлять его входящие и исходящие идентификаторы вершин или метки. Вместо этого вы удаляете край и добавляете новый.
Вот различные способы получения края и обновления его свойств.
Получить ребро можно по его ID:
>>> from bulbs.rexster import Graph
>>> g = Graph()
>>> james = g.vertices.create(name="James")
>>> julie = g.vertices.create(name="Julie")
>>> edge = g.edges.create(james, "knows", julie)
>>> edge2 = g.edges.get(edge.eid) # get the edge again
>>> assert edge == edge2
>>> edge2.someprop = "somevalue"
>>> edge2.save()
Вы можете найти ребро по его свойствам, если они есть и они проиндексированы:
# will return an iterator or None edges (may return more than one)
>>> edges = g.edges.index.lookup(someprop="somevalue")
>>> edge = edges.next()
>>> edge.someprop = "newvalue"
>>> edge.save()
# will return 1 or None edges (or an error if more than 1 edge found)
>>> edge = g.edges.index.get_unique(someprop="somevalue")
>>> edge.someprop = "newvalue"
>>> edge.save()
Вы также можете получить преимущество, используя Gremlin, пройдя его вершины:
>>> from bulbs.rexster import Graph
>>> g = Graph()
>>> script = "g.V('name',name1).outE(label).as('e').inV.has('name',name2).back('e')"
>>> params = dict(name1="James", label="knows", name2="Julie")
>>> edges = g.gremlin.query(script, params)
>>> edge = edges.next()
>>> edge.someprop = "newvalue"
>>> edge.save()
См. паттерн обратного хода гремлина...
Но самый эффективный способ обновить ребро, когда вы не знаете его идентификатор, — это обновить ребро с помощью скрипта Gremlin, который ищет его (таким образом у вас будет только один круговой путь к серверу, а не два):
>>> from bulbs.rexster import Graph
>>> g = Graph()
>>> script = "g.V('name',name1).outE(label).as('e').inV.has('name',name2).back('e').sideEffect{it.someprop = someprop}"
>>> params = dict(name1="James", label="knows", name2="Julie", someprop="somevalue")
>>> edges = g.gremlin.query(script, params)
>>> edge = edges.next()
>>> edge.someprop
'somevalue'
См. https://github.com/tinkerpop/gremlin/wiki/Updating-a-Graph
И для удобочитаемости, вместо того, чтобы писать однострочники Gremlin в Python REPL, я бы поместил свои скрипты Gremlin в файл gremlin.groovy
, как показано здесь:
http://bulbflow.com/docs/api/bulbs/groovy/
Вот реальный пример использования Gremlin для получения или создания преимущества:
https://github.com/espeed/lightbulb/blob/master/lightbulb/gremlin.groovy#L88
И подробное объяснение кода здесь:
Есть ли эквивалент фиксации в каркасе лампочки для neo4j
person
espeed
schedule
25.08.2013