问题描述
简单的问题:我正在使用 Neo4-OGM(与 Quarkus)与我的 Neo4J DB(最新版本)交互。
我有一个实体“Contact”,我添加了@Labels 以便能够在运行时管理额外的标签。
@NodeEntity
public class Contact {
@Id
@GeneratedValue(strategy = UuidStrategy.class)
private String identifier;
// some properties and relations...
@Labels
private List<String> labels;
}
这会正常工作。
但是现在,我想使用带有过滤器的 loadAll 方法来查询我的数据库,而不是自己编写密码查询。
不幸的是,我看不到如何获得以下密码查询的任何等价物:
MATCH (n:`Contact`:`Label_added_in_labels`) RETURN n
是否支持?还是我必须自己写密码? (这很好,但如果不需要,我不想写它们)。
解决方法
Neo4j-OGM 中的 Filter
是基于属性的,很遗憾无法帮助您解决这个问题。
但是如果您不想编写自己的语句,您可以使用 Neo4j CypherDSL。
为此,您可以将以下依赖项添加到您的项目中
<dependency>
<groupId>org.neo4j</groupId>
<artifactId>neo4j-cypher-dsl</artifactId>
<version>2021.3.0</version> // <- currently the latest version
</dependency>
并将其与 Neo4j-OGM Session
结合使用,例如:
Node node = Cypher.node("Contact","Label_added_in_labels");
Statement statement = Cypher.match(node.named("n")).returning(node).build();
Iterable<User> contacts = session.query(Contact.class,statement.getCypher(),Collections.emptyMap());