使用SDN 3,可以使用Neo4jOperations.convert(Object value,Class类型)将返回Iterable>的密码查询的结果转换为Neo4j域类(带有@NodeEntity注解)。例如:
Map<String,Object> results = repository.findSomething("John");
for(Map<String,Object> row : results) {
Person person = neo4jOperations.convert(row.get("person"), Person.class);
...
}
// Repository method
@Query("MATCH (person:Person)-[rel]->(node) WHERE person.firstName = {firstName} RETURN DISTINCT person, COUNT(rel) ORDER BY COUNT(rel)"
Iterable<Map<String,Object>> findSomething(@Param("firstName") String firstName);由于SDN 4中的Neo4jOperations中不再存在T转换(对象值,类类型),这在SDN 4中的等价性是什么?
simple-mapping没有介绍如何显式或隐式地完成映射/转换。
我在用快照构建。
任何帮助都很感激。
发布于 2015-06-29 09:13:50
正如Luanne所建议的,您现在需要分两步完成。对于存储库方法,您可以尝试这样的方法:
@Query("MATCH (p:Person)-[rel]->(node) WHERE p.firstName = {firstName} RETURN DISTINCT p ORDER BY COUNT(rel)")
Iterable<Person> findSomething(@Param("firstName") String firstName);这应该会以正确的顺序返回您想要的Person实体,尽管我很感激实际的计数不会被映射,因此您必须发出第二个查询才能找到计数。
如果您不需要实际的Person实体,而只需要这些节点的一些属性,那么解决方法可能是映射到@QueryResult对象。就像这样:
@Query("MATCH (p:Person)-[rel]->(node) WHERE p.firstName = {firstName} RETURN DISTINCT p.firstName, p.surname, p.dateOfBirth, COUNT(rel) AS rank ORDER BY rank")
Iterable<PersonQueryResult> findSomething(@Param("firstName") String firstName);...where PersonQueryResult是一个带有@QueryResult注释的POJO,它的setters/getters对应于查询的return子句中列出的属性。
发布于 2015-06-29 03:21:28
对于这个用例,您必须返回ID(person)并使用repository.findOne或neo4jOperations.load。
https://stackoverflow.com/questions/31069679
复制相似问题