跳转至

索引介绍

Nebula Graph 支持两种类型索引:原生索引和全文索引。

和一般数据库意义上的索引概念不同,Nebula Graph中的索引没有加速查询的功能,是用于定位到数据的必要前置条件。

原生索引

原生索引可以基于指定的属性查询数据,有如下特点:

  • 包括 Tag 索引和 Edge type 索引。
  • 必须手动重建索引(REBUILD INDEX)。
  • 支持创建同一个 Tag 或 Edge type 的多个属性的索引(复合索引),但是不能跨 Tag 或 Edge type。

原生索引操作

全文索引

全文索引是基于Elastic Search来实现的,用于对字符串属性进行前缀搜索、通配符搜索、正则表达式搜索和模糊搜索,有如下特点:

  • 只允许创建一个属性的索引。
  • 只能创建指定长度(不超过 256 字节)字符串的索引。
  • 不支持逻辑操作,例如ANDORNOT

Note

如果需要进行整个字符串的匹配,请使用原生索引。

全文索引操作

在对全文索引执行任何操作之前,请确保已经部署全文索引。详情请参见部署全文索引部署 listener

部署完成后,Elasticsearch 集群上会自动创建全文索引。不支持重建或修改全文索引。如果需要删除全文索引,请在 Elasticsearch 集群上手动删除。

使用全文索引请参见使用全文索引查询

没有 NULL 值索引

不支持对值为 NULL 的属性创建索引。

没有唯一索引

在 Cypher 中,可以通过 Constrains 实现属性值的唯一性限制。在 MySQL 中,可以建立唯一索引来限制某字段只有唯一值。在 nGQL 中没有属性的唯一索引(用户自行保证属性值的唯一性)。

数字、日期和时间类型的范围查询

原生索引还支持对数字、日期和时间类型的属性进行范围查询,不支持其他属性类型的范围查询。


最后更新: March 7, 2023