- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Spring Boot 2.3.4 之前,我一直在使用 @QueryResult 注释将一些自定义 Cypher 查询响应映射到 POJO。我现在正在测试 Spring Boot 2.4 first RC 并尝试按照有关如何删除 OGM 的说明进行操作,因为支持已被删除。我成功地用此处提供的注释替换了其他注释:
https://neo4j.github.io/sdn-rx/current/#migrating
但我现在只剩下我的 @QueryResult 注释,但没有指定任何内容。当我删除它们时,我收到映射错误:
org.springframework.data.mapping.MappingException: Could not find mappable nodes or relationships inside Record
我查阅了一些 Mapping 解释,但问题是:我的自定义 POJO 不代表数据库中的任何实体,也不代表实体的一部分。它们是来自不同节点的相当相关的位。
(a:Node {label:"my label"})-[:MY_REL]->(b:Node)
出于我的目的,我不需要在响应中获取节点,所以我的 POJO 只有 2 个属性:
RETURN a.label AS source, COLLECT(b.label) AS targets
我的 POJO 只是用 @QueryResult 进行了注释,以便完成映射。
最佳答案
Spring Data Neo4j 6 现在支持与其他 Spring Data 模块一致的投影(以前称为 @QueryResult
)。
话虽如此,假设此 @Query
,您必须做的最简单的事情写在 Neo4jRepository<Node,...>
, 也会返回 a
.
我知道这首先听起来很荒谬,但是在选择存储库抽象时,您说在映射阶段应该处理的所有内容都是 Node
并且您想将其属性(或子集)投影到 POJO(DTO 投影)中。 SDN 在开始映射时无法确保您确实在使用正确的类型,因此它会抛出您面临的异常。 Neo4j-OGM 在幕后更轻松地映射 @QueryResult
s 但不幸的是,这个方向也错了。
如果您的用例如您所描述的那样简单,我强烈建议您使用 Neo4jClient
(docs)这使您可以直接访问映射。
它有一个用于查询和手动映射的流畅 API,并且它参与您的存储库正在运行的正在进行的 Spring 事务。
有很多关于预测的内容,所以我建议也阅读 the section in the documentation .
关于java - 从 SDN+OGM 切换到 SDN/RX 时替换 @QueryResult,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64718174/
我从后端获取一些数据并将其存储到变量 queryResult 中。但是每当我按下网页上的查询按钮时,代码都会返回一个错误,指出渲染错误: TypeError: Cannot read property
我正在使用 org.springframework.data spring-data-neo4j
我正在使用 Java Hector API 从 Cassandra 数据库检索数据,如下所示: public static void retrieveData() { try {
定义 @QueryResult 类的最佳方法是什么?我定义了一个用查询注释的存储库方法,如 "MATCH(p:Person{name:{0}) - [r]-(e) RETURN distinct la
我正在使用 neo4j + spring 数据。为了访问数据,我正在使用扩展 GraphRepository 的接口(interface)。例如 public interface EntryRepos
我正在编写 TYPO3 - 网站扩展程序。因为我使用的是 Extbase 框架,所以我有一个存储库类 (Tx_Extbase_Persistence_Repository),我在其中连续执行两个 sq
我正在运行最新版本的 dockerized 版本。 我的问题是当我添加 mod-eluna-lua-engine模块,我收到以下错误: [ 16%] Building CXX object src/c
我正在使用 Apache Chemistry OpenCMIS java 库。给定一个 QueryResult (例如,我通过搜索元数据属性找到了一个文档或一堆文档),这是检索 Document 对象
所以我有一个查询,虽然我的查询可能会返回 20 个结果,但我只希望它显示前 9 个结果。有一个愚蠢的原因,我不只是将查询结果限制为 9,为此我需要知道如何在 $i 达到 9 时停止 while 函数。
我无法返回response.query_result。 我想返回结果[“action”],结果[“query_text”][“fulfillment_text”]。 我已尝试response.quer
我尝试了使用 Breeze 和 API Controller 、使用过滤器(部分使用自定义对象,另一部分使用 ODataQueryOptions)加载项目列表的不同方法,但结果证明它们都不是真正成功的
我想介绍 Pageable支持我通过 SDN 4 Repository 方法的自定义 Cyper 查询: @Query(value = "MATCH (parentD)-[:CONTAINS]->(c
我有以下 Java 代码: Index userNameIndex = userTable.getIndex("userNameIndex"); ItemCollection userItems =
在 Spring Boot 2.3.4 之前,我一直在使用 @QueryResult 注释将一些自定义 Cypher 查询响应映射到 POJO。我现在正在测试 Spring Boot 2.4 firs
我有一个 ViewModel 并根据 this post of spring.io 在某些字段上添加 json 注释如下所示: public class SurveyViewModel{ @J
这个函数的执行顺序是什么: var queryResult = names.OrderBy(item => item).Where(it => it.StartsWith("S")) 最佳答案 我假设
我正在使用 dialogflow v1使用 spring boot java 作为 webhook 使用: http://mvnrepository.org/artifact/ai.api/libai
所以我在这里失去了理智:/我正在尝试使用 Firebase 的功能在用户之间发送通知。 该函数看起来没问题,并成功获取路径(在日志中检查过),但在尝试访问文档时,即使文档存在,仍返回“无文档”。我遇到
我是一名优秀的程序员,十分优秀!