【问题标题】:Spring data repository's method to find by the field of a fieldSpring数据存储库的方法通过字段的字段查找
【发布时间】:2023-04-06 06:08:01
【问题描述】:

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

注册用户有一个用户类型的字段。我想在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;
    ...
}

【问题讨论】:

  • U 在这 2 个实体之间使用 onetoone 映射。这意味着你无法为同一个注册用户找到很多用户。我认为你应该使用 onetomany 注释

标签: java spring hibernate spring-repositories


【解决方案1】:

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

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

如果没有找到整个字段名称,还有一些代码将大写字符视为字段分隔符。因此,如果您在 RegisteredUser 中没有 userUsername 字段,则第二个变量是

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

【讨论】:

  • 第二个选项有效(第一个没试过),谢谢。顺便说一句,我只是想找一个注册用户(因为是一对一的关系),所以最后的方法签名是:findOneRegisteredUserByUserUsername(String username)
  • 如果我们在主实体中有类似的属性,我们应该为 arg 使用什么?例如,我在所有实体中使用id 作为主键,那么如果我想根据另一个实体的 id 查找所有主要实体,我应该使用什么?
【解决方案2】:

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

您不必创建任何存储库接口,并且可以直接在客户端应用程序中使用提供的查询生成器。

查询示例:

/search?filter= 平均(收视率)> 4.5 brand.name in (“奥迪”、“路虎”)(年> 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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-12-04
    • 2017-01-03
    • 2018-08-13
    • 2013-09-23
    • 2020-12-25
    • 2018-07-08
    • 2015-10-18
    • 1970-01-01
    相关资源
    最近更新 更多