Neo4j - Is there a cypher query syntax to list (show) all indexes in DB?

前端 未结 6 1592
谎友^
谎友^ 2020-12-24 01:27

I\'m looking for something similar to the MySQL ( SHOW INDEXES ). I was able to get a list of indexes using py2neo in Python

graphDB = neo4j.GraphDatabaseS         


        
6条回答
  •  感情败类
    2020-12-24 02:18

    Not yet. In Neo4j 2.0 more cypher friendly indexing was introduced and you can issue some DDL commands to create and drop indices and constraints, but as of 2.01 that's it (see docs). In 1.9 you can't define that type of schema with cypher at all.

    --

    There are many ways outside of cypher, for instance

    In neo4j-shell you can

    • list legacy indices with index --indexes
    • list all label indices and constraints with schema
    • list indices and constraints for specific label with schema ls -l :YourLabel

    In neo4j-browser you can

    • list all label indices and constraints with :schema
    • list indices and constraints for specific label with :schema ls -l :YourLabel

    Most APIs that let you execute cypher queries will also provide ways to query schema, such as

    • Native Java API
      • GraphDatabaseService.schema().getConstraints() and .getIndexes() for label schema
      • GraphDatabaseService.index().nodeIndexNames() and .relationshipIndexNames() for legacy indices
    • REST calls to
      • /db/data/schema/ endpoints for label based schema
      • and to /db/data/index/node/ and /db/data/index/relationship/ for legacy indices

提交回复
热议问题