Добавление вершины графа непосредственно в CosmosDB в формате GraphSON с использованием gremlinpython - PullRequest
0 голосов
/ 05 июня 2018

Я использую gremlinpython для подключения к графику CosmosDB и хотел бы иметь возможность напрямую добавлять вершину, используя словарь в формате GraphSON.В частности, я бы хотел избежать необходимости динамически создавать запрос gremlin, например:

"g.addV('person').property(...)..."

, и вместо этого запускать что-то вроде:

my_dict = {'id':'something', 'label':'person', 'outE':{}, 'properties':{}}
_gremlin_insert_vertex = "g.addV('person').use_my_graphson_dict({})".format(my_dict)
callback = client.submitAsync(_gremlin_insert_vertex)

или что-то в этом роде.Портал Azure содержит JSON-представление вершин из запроса, который я запускаю (например, "g.V()"), но я хотел бы иметь возможность получить его в Python с помощью gremlinpython, сделать обновления, а затем отправить JSON-запрос обратно, чтобы обновить или добавитьвершина.Кажется, я не могу найти какую-либо документацию о том, как конвертировать между объектами или запросами GraphSON dict и gremlin.

Ответы [ 2 ]

0 голосов
/ 29 июля 2019

Это на год позже, так что к настоящему моменту вы либо решили это, либо уже все равно, но для потомков ...

Вы можете использовать python-клиент sql для своей коллекции графов и использовать документ вставкиспособ отправить json, который имеет действительную структуру Graphson для вершины:

Примерно так:

{
    "label": "person",
    "firstName": [{
        "_value": "Thomas",
        "id": "5267ec4b-a39e-4d77-8dea-668cb36307bc"
    }],
    "lastName": [{
        "_value": "Andersen",
        "id": "2e5271a6-ddd8-48b9-8ff6-be41e19f82f8"
    }],
    "age": [{
        "_value": 44,
        "id": "1c9a57cc-3324-4a0c-b4c3-d494fbb3fb81"
    }],
    "PartitionKey": "123",
    "id": "a9b57684-16bf-47d9-8761-570bab43ca7b"
}

Я написал в блоге об этом некоторое время назад -Я только проверял это в .NET SDK все же.

0 голосов
/ 05 июня 2018

В Gremlin такого API просто нет.У него нет шага, который может принять GraphSON или Dictionary (Map в Java), чтобы преобразовать его в property() шаги.В течение многих лет в сообществе TinkerPop велась значительная дискуссия на эту тему, поскольку удобство такого шага для пользователя, пожалуй, высоко, особенно в контексте, который вы описываете.К сожалению, введение Map не очень хорошо вписывается в API, так как это первоначально выглядело бы, поскольку оно не позволяет должным образом устанавливать мульти-свойства, если подпись шага не приняла Map<Object,List<Object>> (то есть в Python, где Dictionary, гдеключ - String или T, а значение - List произвольных объектов), который сложнее построить и обдумать.Более того, этот API плохо учитывает мета-свойства, если рассматривать их в общем контексте их установки.Есть и другие аргументы против этого, но те, которые имеют тенденцию торчать в моей голове.

Что касается шага, принимающего сам GraphSON (который, я полагаю, ослабит некоторые из упомянутых выше проблем с multi / meta-свойствами), я не думаю, что это когда-либо предлагалось.Я не уверен, как это будет работать, поскольку GraphSON является функцией операций ввода-вывода, а сам язык Gremlin просто никогда не знал об этом.IO - абстракция далеко от Гремлин, и я не знаю, хорошо ли она там подходила.Я также думаю, что большинство пользователей жаловались на сложность GraphSON (словари со встроенными списками или списками и т. Д.) И что создание GraphSON вручную нетривиально, и поэтому я сомневаюсь, что многие найдут такой API привлекательным для них.Мульти / мета-свойства снова бьют!:)

Я бы также сказал, что TinkerPop очень против создания строк Gremlin.Вы вынуждены сделать это сейчас в CosmosDB, поскольку они еще не поддерживают API байт-кода.С этой поддержкой (над чем они работают) вы больше не будете отправлять Gremlin в качестве значения String, а вместо этого напишите Gremlin на вашем любимом родном языке (в вашем случае Python ).Таким образом, разработка путей, которые еще больше побуждают пользователей «создавать строки» любого типа, GraphSON или Gremlin, вероятно, будет препятствовать.

Теперь в Python вы можете создать этот метод самостоятельно как часть пользовательского Gremlin.DSL, который обычно принимает Dictionary и преобразует его в property() вызовы.Поскольку логика будет специфичной для вашего приложения, вы можете учитывать любые проблемы с мета / множественными свойствами, которые у вас могут быть или не быть.Вы можете прочитать больше о том, как создавать DSL здесь и узнать больше о шаблонах для реализации в этой серии постов в блоге: Часть I , Часть II и Часть III .

Я думаю, что мы могли бы увидеть этот вид API, родной для Gremlin, в 4.x, когда растет популярность отказа от поддержки мульти / мета-свойств, но до тех пор нетбыло много хороших идей.

...