5

在 Neo4j(3.0 版)中,以下查询返回相同的结果:

1. MATCH (a:Label) WHERE a.property = "Something" RETURN a
2. MATCH (a:Label {property: "Something"}) RETURN a

在处理一些大型数据集时,我注意到(并使用EXPLAINand验证PROFILE)在某些情况下,像第二个这样的查询执行得更好更快。虽然存在两个版本表现相同的其他实例,但我还没有看到第一个版本表现更好的实例。

neo4j 的文档和教程也分门别类。两者之间没有明确的比较。docs 和 tuts 使用这两个版本,通常倾向于第一个(可能是因为非精确匹配只能使用该WHERE子句完成)。但指南还指出,越早缩小搜索范围,搜索速度就越快。

  1. 我对这两个版本总是返回相同的结果是对的吗?
  2. 第二个版本通常会表现得更好,因为它更早地缩小了搜索范围,我说得对吗?
4

1 回答 1

3
  1. 是的
  2. 不,两者都评估基本相同的查询计划。由于 Neo4j 使用基于成本的优化器,查询计划可能会随着时间的推移而改变,因为优化器考虑改变(也许现在有更多的数据,所以索引查找比 NodeByLabelScan 便宜)。
于 2016-05-14T12:28:53.573 回答