簡體   English   中英

如何使用 Neo4j-OGM 使用運行時管理的標簽創建查詢?

[英]How to create queries using runtime managed labels using Neo4j-OGM?

簡單的問題:我正在使用 Neo4-OGM(帶 Quarkus)與我的 Neo4J DB(最新版本)進行交互。

我有一個實體“聯系人”,我添加了 @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());

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM