Не удалось найти метод: DefaultGraphTraversal.to с плагином neo4j и сервером gremlin - PullRequest
0 голосов
/ 21 мая 2019

Я использую плагин gremlin для nodejs, который общается с сервером gremlin со встроенным графом neo4j.Я могу запрашивать и создавать вершины, но не могу создать ребра из-за ошибки «Не удалось найти метод: DefaultGraphTraversal.to».Любые идеи ??

Я могу создавать вершины и ребра, используя консоль gremlin, подключенную к тому же серверу gremlin, что и программа nodejs.

Консоль и сервер Gremlin 3.4.1 Gremlin NodeJS npm 3.4.1 Плагин Tinkerpop Neo4J-gremlin: 3.4.1

const gremlin = require('gremlin');
const traversal = gremlin.process.AnonymousTraversalSource.traversal;
const Graph = gremlin.structure.Graph;
const DriverRemoteConnection = gremlin.driver.DriverRemoteConnection;

const g = traversal().withRemote(new DriverRemoteConnection('ws://localhost:8182/gremlin'));

async function run(){

    const phil = await g.V().has('name', 'phil').next();
    console.log("Have Phil: " +JSON.stringify(phil ));

    g.V().has('name', 'stephen').next()
    .then(stephen => {
        console.log("Have Steve: " +JSON.stringify(stephen));
        const e1 = g.V(phil).addE('friends').to(stephen).next();
        console.log(e1);
    })
    .catch(err => console.log(err));

}

run();

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

Have Phil: {"value":{"id":18,"label":"person"},"done":false}
gremlin.js:13
Have Steve: {"value":{"id":7,"label":"person"},"done":false}
gremlin.js:17
Promise { pending }
gremlin.js:19
(node:48830) UnhandledPromiseRejectionWarning: Error: Server error: Could not locate method: DefaultGraphTraversal.to([{value={id=7, label=person}, done=false}]) (599)
    at Connection._handleMessage (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/gremlin/lib/driver/connection.js:265:9)
    at WebSocket._ws.on (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/gremlin/lib/driver/connection.js:128:43)
    at WebSocket.emit (events.js:189:13)
    at Receiver._receiver.onmessage (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/ws/lib/WebSocket.js:141:47)
    at Receiver.dataMessage (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/ws/lib/Receiver.js:380:14)
    at Receiver.getData (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/ws/lib/Receiver.js:330:12)
    at Receiver.startLoop (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/ws/lib/Receiver.js:165:16)
    at Receiver.add (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/ws/lib/Receiver.js:139:10)
    at Socket._ultron.on (/Users/byronbailey/OneDrive - Cargill Inc/VSC/GraphTest/node_modules/ws/lib/WebSocket.js:138:22)
    at Socket.emit (events.js:189:13)
warning.js:18
(node:48830) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)
warning.js:18
(node:48830) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

1 Ответ

0 голосов
/ 22 мая 2019

Проблема заключалась в типе данных параметров.Я пробовал разные версии этого решения раньше, но, видимо, все же не попал в цель.Строка кода addE должна быть такой, как показано ниже. Этот пример Azure помог соединить точки.

гВ (phil.value.id) .addE ('знает'). К (гВ (stephen.value.id)). Next ()

...