首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用Neo4j-OGM创建使用运行时管理标签的查询?

如何使用Neo4j-OGM创建使用运行时管理标签的查询?
EN

Stack Overflow用户
提问于 2021-07-06 23:06:29
回答 1查看 17关注 0票数 0

简单的问题:我正在使用Neo4-OGM (带有Quarkus)与我的Neo4J DB (最新版本)进行交互。

我有一个实体"Contact“,我添加了@Labels,以便能够在运行时管理额外的标签。

代码语言:javascript
复制
@NodeEntity
public class Contact {

    @Id
    @GeneratedValue(strategy = UuidStrategy.class)
    private String identifier;

    // some properties and relations...

    @Labels
    private List<String> labels;

}

这将工作得很好。

但是现在,我想使用带有过滤器的loadAll方法来查询我的数据库,而不是自己编写一个cypher查询。

不幸的是,我看不到如何获得与以下cypher查询相同的结果:

代码语言:javascript
复制
MATCH (n:`Contact`:`Label_added_in_labels`) RETURN n

是否支持?否则我得自己写密码了?(这很好,但如果不需要的话,我不想写它们)。

EN

回答 1

Stack Overflow用户

发布于 2021-07-29 14:08:17

Neo4j-OGM中的Filter是基于属性的,遗憾的是它不能帮助你。但是,如果您不想编写自己的语句,则可以使用Neo4j CypherDSL。

为此,可以将以下依赖项添加到项目中

代码语言:javascript
复制
<dependency>
    <groupId>org.neo4j</groupId>
    <artifactId>neo4j-cypher-dsl</artifactId>
    <version>2021.3.0</version> // <- currently the latest version
</dependency>

例如,将其与Neo4j-OGM Session结合使用

代码语言:javascript
复制
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());
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68273029

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档