索引介绍¶
NebulaGraph 支持两种类型索引:原生索引和全文索引。
和一般数据库意义上的索引概念不同,NebulaGraph 中的索引没有加速查询的功能,是用于定位到数据的必要前置条件。
原生索引¶
原生索引可以基于指定的属性查询数据,有如下特点:
- 包括 Tag 索引和 Edge type 索引。
- 必须手动重建索引(
REBUILD INDEX
)。
- 支持创建同一个 Tag 或 Edge type 的多个属性的索引(复合索引),但是不能跨 Tag 或 Edge type。
原生索引操作¶
全文索引¶
全文索引是基于 Elasticsearch 来实现的,用于对字符串属性进行前缀搜索、通配符搜索、正则表达式搜索和模糊搜索,有如下特点:
- 只允许创建一个属性的索引。
- 不支持逻辑操作,例如
AND
、OR
、NOT
。
Note
如果需要进行整个字符串的匹配,请使用原生索引。
没有 NULL 值索引¶
不支持对值为 NULL 的属性创建索引。
没有唯一索引¶
在 Cypher 中,可以通过 Constrains 实现属性值的唯一性限制。在 MySQL 中,可以建立唯一索引来限制某字段只有唯一值。在 nGQL 中没有属性的唯一索引(用户自行保证属性值的唯一性)。
数字、日期和时间类型的范围查询¶
原生索引还支持对数字、日期和时间类型的属性进行范围查询,不支持其他属性类型的范围查询。
最后更新:
July 6, 2023