我是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 ...,
答案 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属性将为空值。