如何使用带有Spring启动GraphRepository的Neo4j获取两个节点之间的关系?

时间:2015-08-31 15:36:07

标签: neo4j spring-boot spring-data-neo4j-4

我是Neo4j的初学者,我对neo4j图模型有基本的了解。我想知道如何使用java和cyper查询获取两个节点之间的关系。我有两个实体,如关注用户和角色。我想要检索用户的角色。我有cyper查询工作正常。当我尝试通过neo4j实体类时,我错过了一些东西。请看下面的代码段,

用户实体类:

public class Users extends Entity{

    /*private Long userId;*/
    private String name;
    private String email;
    private String login;
    private String password;

    @Relationship(type = "HAS_ROLE")
    Set<Roles> roles=new HashSet<Roles>();

    public Users(){
        roles = new HashSet<Roles>();
    }

    public Users(Users user) {
        super();
        this.name = user.getName();
        this.login = user.getLogin();
        this.password = user.getPassword();
        this.roles = user.getRoles();
    }

    public Set<Roles> getRoles() {
        return roles;
    }

    public void setRoles(Set<Roles> roles) {
        this.roles = roles;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getLogin() {
        return login;
    }

    public void setLogin(String login) {
        this.login = login;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

角色实体类:

public class Roles extends Entity implements GrantedAuthority{

    private static final long serialVersionUID = 1L;

    private String name;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String getAuthority() {
        return name;
    }
}



 public interface UserRepository extends GraphRepository<Users> {

     @Query("MATCH (user:Users)-[r]->(role:Roles) WHERE user.login = {0} RETURN user, role");  
     Users findByLogin(String login);

   }

有人可以帮我知道为用户取得角色吗?

TIA ...,

2 个答案:

答案 0 :(得分:2)

Derived finders使用depth为1,因此您可以

 public interface UserRepository extends GraphRepository<Users> {
   Users findByLogin(String login);
 }

如果要使用@Query,请返回路径(并根据需要调整深度)。此示例与上面的深度= 1

相同
public interface UserRepository extends GraphRepository<Users> {
   @Query("MATCH p=(user:Users)-[r*0..1]->() WHERE user.login = {0} RETURN p") 
   Users findByLogin(String login);
 }

答案 1 :(得分:2)

重要的是要知道,对于使用cypher和java获取节点,必须在RETURN子句中包含第一个节点和空值的节点之间的关系:

@Query("MATCH (u:User)<-[rel:RELATIONSHIP]-(r:Roles) " +
            " RETURN u,r,rel")
    Users findByLogin(String login);

如果不这样,Reference中的Stay属性将为空值。