ioredisgraph

    2.1.4 • Public • Published

    Libraries.io dependency status for latest release Node CI

    ioredisgraph

    A javascript client for RedisGraph based on the excellent ioredis client.

    Literally based off ioredis. This module wraps ioredis, adds a couple commands, and returns an array of objects from each query (as well as the query meta information).

    let RedisGraph = require('ioredisgraph');
    
    async function demo () {
      let graph = new RedisGraph('MotoGP')
      await graph.query("CREATE (:Rider {name:'Valentino Rossi'})-[:rides]->(:Team {name:'Yamaha'}), (:Rider {name:'Dani Pedrosa'})-[:rides]->(:Team {name:'Honda'}), (:Rider {name:'Andrea Dovizioso'})-[:rides]->(:Team {name:'Ducati'})")
      let ridingForYamaha = await graph.query("MATCH (r:Rider)-[:rides]->(t:Team) WHERE t.name = 'Yamaha' RETURN r,t")
    
      console.log(ridingForYamaha)
      // [ { 'r.name': 'Valentino Rossi', 't.name': 'Yamaha' },
      // meta: { queryInternalExecutionTime: '1.446600 milliseconds' } ]
    
      await graph.delete()
    }
    
    demo()
    

    Usage

    Constructor

    ioredisgraph has all the same constructor options as ioredis, but adds a graphName argument.

    Add graph name as first argument to constructor:

    let graph = new RedisGraph('DEMO_GRAPH')

    let graph = new RedisGraph('DEMO_GRAPH', 6379)

    or add to options object:

    let graph = new RedisGraph({graphName: 'DEMO_GRAPH', port: 6379})

    Methods

    These methods are added. All other methods usually available to an ioredis client are accessible.

    graph.query(cypherString) Pass in a string for your cypher query. Results are an array of object. Each object has properties based on the name used in the query. access results.meta for the meta information redisgraph returns.

    graph.delete() Deletes database

    graph.explain(cypherString)

    Performance

    RedisGraph supports a special --compact argument on queries, which improves performance by having responses include enums instead of looking up the string values for property names, label names, and relationship type names. This client does not use --compact currently. Create an issue to support this, we are currently waiting for a solution to https://github.com/luin/ioredis/issues/895

    Install

    npm i ioredisgraph

    DownloadsWeekly Downloads

    12

    Version

    2.1.4

    License

    ISC

    Unpacked Size

    12 kB

    Total Files

    7

    Last publish

    Collaborators

    • avatar