Azure Cosmos + Gremlin NodeJS,如何以脚本形式提交流畅的查询(不是字节码-我知道尚不支持)

时间:2019-11-12 09:24:40

标签: node.js azure gremlin azure-cosmosdb-gremlinapi

我正在尝试在nodejs中为cosmos db编写流畅的gremlin查询,即使它们以字符串形式提交。我已经阅读了文档,并且在一些github线程中看到了它,尽管还不支持字节码,但可以将其作为脚本提交。

我到目前为止的代码:

配置客户端功能:


export const CosmosConn = async (): Promise<driver.Client> => {
    try {
        const cosmosKey: string = await GetSecret('cosmos-key');
        const cosmosEndpoint: string = await GetSecret('cosmos-endpoint');

        const authenticator: driver.auth.PlainTextSaslAuthenticator = new gremlin.driver.auth.PlainTextSaslAuthenticator(
            '/dbs/main/colls/main',
            cosmosKey
        );
        const client: driver.Client = new gremlin.driver.Client(cosmosEndpoint, {
            authenticator,
            traversalsource: 'g',
            rejectUnauthorized: true,
            mimeType: 'application/vnd.gremlin-v2.0+json'
        });

        return client;
    } catch (err) {
        console.error(err);
    }
};

现在下面的这两个是临时的,因为我将为每个查询等待几次CosmosConn,但这是针对Azure函数的,因此我尚未进行优化:

export const Graph = async (query: gremlin.process.Bytecode): Promise<any> => {
    const db = await CosmosConn();
    const translator = new gremlin.process.Translator(
        new gremlin.process.AnonymousTraversalSource()
    );
    return db.submit(translator.translate(query));
};

export const getGremlin = async () => {
    const db = await CosmosConn();
    return gremlin.process.traversal().withRemote(db);
};

现在,当我尝试使用它时:

    const g = await getGremlin();
        const query = g
            .V()
            .hasLabel('client')
            .getBytecode();

        const test = await Graph(query);

这当然会引发错误:

Gremlin Query Syntax Error: Script compile error: Unexpected token: 'Object'; in input: '[objectObject'. @ line 1, column 9.

4 个答案:

答案 0 :(得分:1)

您是否尝试过在提交之前打印translator.translate(query)

根据我的经验,翻译器对非平凡查询的支持非常有限。

根据Microsoft的说法,他们计划在12月19日支持流畅的API,因此最好等待官方支持。

答案 1 :(得分:0)

正是这些类型阻止我以与CosmosDB兼容的方式初始化翻译器。

movie(id: $movieId) {
  linkedFrom {
    movieLocationCollection { 
      items {//fields with non-localized values} 
    }
  }
}

有效。

答案 2 :(得分:0)

下面的黎明是在TypeScript中使用Translator将字节码查询转换为CosmosDB的字符串查询的示例。我不推荐这种解决方案,就像其他回应指出的那样:它是有限的。请改用AWS Neptune,或者等到MS在CosmosDB中实现字节码查询。

async function test(): Promise<void> {
   // Connection:
   const traversal = Gremlin.process.AnonymousTraversalSource.traversal;
   const DriverRemoteConnection = Gremlin.driver.DriverRemoteConnection;
   const g = traversal().withRemote(new DriverRemoteConnection("ws://localhost:8182/gremlin"));

   // Create translator
   const translator = new Gremlin.process.Translator(g);

   // Convert bytecode query to string query for CosmosDB:
   console.log(translator.translate(g.V().hasLabel('person').values('name').getBytecode()))
}

test();

答案 3 :(得分:-1)

这里是测试用例的链接,让 getbytecode 翻译工作。

https://github.com/apache/tinkerpop/blob/master/gremlin-javascript/src/main/javascript/gremlin-javascript/test/unit/translator-test.js#L31

编辑:-

这是上面链接中的示例测试用例

it('should produce valid script representation from bytecode glv steps', function () {
      const g = new graph.Graph().traversal();
      const script = new Translator('g').translate(g.V().out('created').getBytecode());
      assert.ok(script);
      assert.strictEqual(script, 'g.V().out(\'created\')');
});