CREATE INDEX

Prerequisites

Before you create an index, make sure that the relative tag or edge type is created. For how to create tags or edge types, see CREATE TAG and CREATE EDGE .

For how to create full-text indexes, see Deploy full-text index .

Must-read for using indexes

The concept and using restrictions of indexes are comparatively complex. You can use it together with LOOKUP and MATCH statements.

You can use CREATE INDEX to add native indexes for the existing tags, edge types, or properties. They are usually called as tag indexes, edge type indexes, and property indexes.

  • Tag indexes and edge type indexes apply to queries related to the tag and the edge type, but do not apply to queries that are based on certain properties on the tag. For example, you can use LOOKUP to retrieve all the vertices with the tag player .
  • Property indexes apply to property-based queries. For example, you can use the age property to retrieve the VID of all vertices that meet age == 19 .
  • If a property index i_TA is created for the property A of the tag T , the indexes can be replaced as follows (the same for edge type indexes):

  • The query engine can use i_TA to replace i_T .
  • In the MATCH statement, i_T cannot replace i_TA for querying properties.
  • In the LOOKUP statement, i_T may replace i_TA for querying properties.

    Legacy version compatibility

    In previous releases, the tag or edge type index in the LOOKUP statement cannot replace the property index for property queries.

    Although the same results can be obtained by using alternative indexes for queries, the query performance varies according to the selected index.

    Caution

    Indexes can dramatically reduce the write performance. The performance can be greatly reduced . DO NOT use indexes in production environments unless you are fully aware of their influences on your service.

    Indexes cannot make queries faster. It can only locate a vertex or an edge according to properties or count the number of vertices or edges.

    Long indexes decrease the scan performance of the Storage Service and use more memory. We suggest that you set the indexing length the same as that of the longest string to be indexed. The longest index length is 256 bytes.

    If you must use indexes, we suggest that you:

    Import the data into NebulaGraph.

    Create indexes.

    Rebuild indexes .

    After the index is created and the data is imported, you can use LOOKUP or MATCH to retrieve the data. You do not need to specify which indexes to use in a query, NebulaGraph figures that out by itself.

    If you create an index before importing the data, the importing speed will be extremely slow due to the reduction in the write performance.

    Keep --disable_auto_compaction = false during daily incremental writing.

    The newly created index will not take effect immediately. Trying to use a newly created index (such as LOOKUP or REBUILD INDEX ) may fail and return can't find xxx in the space because the creation is implemented asynchronously. To make sure the follow-up operations work as expected, Wait for two heartbeat cycles, i.e., 20 seconds. To change the heartbeat interval, modify the heartbeat_interval_secs in the configuration files for all services.

    Danger

    After creating a new index, or dropping the old index and creating a new one with the same name again, you must REBUILD INDEX . Otherwise, these data cannot be returned in the MATCH and LOOKUP statements.

    Syntax

    CREATE {TAG | EDGE} INDEX [IF NOT EXISTS] <index_name> ON {<tag_name> | <edge_name>} ([<prop_name_list>]) [COMMENT '<comment>'];
    IF NOT EXISTS
    Detects if the index that you want to create exists. If it does not exist, a new one will be created.
    <index_name>
    The name of the index. It must be unique in a graph space. A recommended way of naming is i_tagName_propName. The name of the index starts with a letter, supports 1 to 4 bytes UTF-8 encoded characters, such as English letters (case-sensitive), digits, and Chinese characters, but does not support special characters except underscores. To use special characters or reserved keywords as identifiers, quote them with backticks. For more information, see Keywords and reserved words.
    <tag_name> | <edge_name>
    Specifies the name of the tag or edge associated with the index.
    <prop_name_list>
    To index a variable-length string property, you must use prop_name(length) to specify the index length. To index a tag or an edge type, ignore the prop_name_list.
    COMMENT
    The remarks of the index. The maximum length is 256 bytes. By default, there will be no comments on an index.
    

    Create tag/edge type indexes

    nebula> CREATE TAG INDEX IF NOT EXISTS player_index on player();
    
    nebula> CREATE EDGE INDEX IF NOT EXISTS follow_index on follow();
    

    After indexing a tag or an edge type, you can use the LOOKUP statement to retrieve the VID of all vertices with the tag, or the source vertex ID, destination vertex ID, and ranks of all edges with the edge type. For more information, see LOOKUP.

    Create single-property indexes

    nebula> CREATE TAG INDEX IF NOT EXISTS player_index_0 on player(name(10));
    

    The preceding example creates an index for the name property on all vertices carrying the player tag. This example creates an index using the first 10 characters of the name property.

    # To index a variable-length string property, you need to specify the index length.
    nebula> CREATE TAG IF NOT EXISTS var_string(p1 string);
    nebula> CREATE TAG INDEX IF NOT EXISTS var ON var_string(p1(10));
    # To index a fixed-length string property, you do not need to specify the index length.
    nebula> CREATE TAG IF NOT EXISTS fix_string(p1 FIXED_STRING(10));
    nebula> CREATE TAG INDEX IF NOT EXISTS fix ON fix_string(p1);
    
    nebula> CREATE EDGE INDEX IF NOT EXISTS follow_index_0 on follow(degree);
    

    Create composite property indexes

    An index on multiple properties on a tag (or an edge type) is called a composite property index.

    nebula> CREATE TAG INDEX IF NOT EXISTS player_index_1 on player(name(10), age);
    

    Caution

    Creating composite property indexes across multiple tags or edge types is not supported.

    NebulaGraph follows the left matching principle to select indexes.