Spring数据存储库的方法,通过字段的字段查找

时间:2016-05-12 17:37:23

标签: java spring hibernate spring-repositories

我有两个实体,一个用户和一个注册用户。

注册用户的字段类型为user。我想在spring数据存储库中有一个与此注册用户实体相关的方法,以通过连接到注册用户的用户的用户名搜索所有注册用户。

因此,这是具有关联用户字段的注册用户实体:

@Entity
public class RegisteredUser implements Serializable {

    ... 
    @OneToOne
    @JoinColumn(name = "USERNAME_FK")
    private User user;
    ...
}

这是一个用户名为

的用户
@Entity
public class User implements Serializable { 
    ...
    @Id
    @Column(nullable = false)
    protected String username;
    ...
}

2 个答案:

答案 0 :(得分:10)

Spring Data(至少1.12.x版本)使用PropertyPath#from方法为从方法名称构造的谓词提取属性的路径。根据{{​​3}},它使用下划线作为“字段分隔符”。所以第一个变体如下

public interface RegisteredUserRepository extends CrudRepository<RegisteredUser,String> {
    List<RegisteredUser> findRegisteredUserByUser_Username(String username);
}

如果找不到整个字段名,还有一些代码将大写字符作为字段分隔符处理。因此,如果userUsername中没有RegisteredUser字段,则第二个varian是

public interface RegisteredUserRepository extends CrudRepository<RegisteredUser,String> {
    List<RegisteredUser> findRegisteredUserByUserUsername(String username);
}

答案 1 :(得分:0)

您也可以简单地使用这样的库,它可以让您构建动态过滤器(支持逻辑运算符、比较器、枚举、日期、布尔值、连接、函数等):https://github.com/turkraft/spring-filter

您无需创建任何存储库界面,并且可以直接在您的客户端应用中使用提供的查询构建器。

示例查询:

<块引用>

/search?filter= average(评分)> 4.5 brand.name ('奥迪'、'路虎')(年份> 2018公里< 50000)和颜色“白色”事故为空

用法:

@GetMapping(value = "/search")
public List<Entity> search(@EntityFilter Specification<Entity> spec, Pageable page) {
  return repo.findAll(spec, page);
}

不要忘记依赖:

<dependency>
    <groupId>com.turkraft</groupId>
    <artifactId>spring-filter</artifactId>
    <version>0.9.5</version>
</dependency>

你也可以检查 rsql,虽然它现在有点过时了https://github.com/jirutka/rsql-parser