0

我正在使用 Spring Data for Neo4j 来访问 Neo4j 图表。我有一个UserRepository带注释的查询,如下所示:

package com.abc.graph.repository;

import java.util.List;
import java.util.Map;

import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.neo4j.annotation.Query;
import org.springframework.data.neo4j.repository.GraphRepository;
import org.springframework.data.neo4j.repository.NamedIndexRepository;
import org.springframework.data.neo4j.repository.RelationshipOperationsRepository;

import com.abc.graph.entity.User;

public interface UserRepository extends GraphRepository<User>, NamedIndexRepository<User>,
        RelationshipOperationsRepository<User> {
    public User findById(String id);

    public Page<User> findByNameLike(String name, Pageable page);

    @Query("START user=node:User(id={0}) " +  
            "MATCH user-[:VISITS]->(location)<-[:VISITS]-(similar_user) " +
            "RETURN similar_user, collect(location) as locations, count(*) as count " + 
            "ORDER BY count desc ")
    public List<Map<String, Object>> findSimilarUsersByPlaceVisited(String userId);
}

我试图从图表中检索的是去过类似地方的用户列表,对于每个用户,他们去过的常见地方是什么。该方法将返回一个列表Map<String, Object>。每个地图都将包含类似similar_userlocations的键count

从调试语句中我可以看到这similar_userorg.neo4j.rest.graphdb.entity.RestNode. 有没有办法将它转换为我的 Spring Data 节点实体com.abc.graph.entity.User

4

1 回答 1

3

您可以使用以下方法手动执行此操作:

template.createEntityFrom[Stored]State(userNode[,User.class)

或者,您将一个Iterable或定义为使用 getter 为三列Collection注释的接口的结果。@MapResult它要么自动将 getter 名称映射到结果列,要么您可以提供要映射到的名称。

@MapResult
interface SimilarUser {

   @ResultColumn("count") int getCount();
   @ResultColumn("similar_user") User getUser();
   @ResultColumn("locations") Collection<Location> getLocations();
}
于 2013-03-18T12:15:23.017 回答