验证Spring Jpa查询中参数的最小长度

时间:2019-01-29 09:11:29

标签: java validation spring-data-jpa

我们有一个数据对象Foo,它具有字符串属性Bar,以及一个jpa信息库,其中包含一种通过Bar查找Foo的方法:

@Entity
@Table(name = "FOO")
public class Foo {

    @Id
    @GeneratedValue
    private Long id;

    @Column(name = "BAR", length = 16, nullable = false)
    private String bar;

    public String getBar() {
        return bar;
    }

    public void setBar(String bar) {
        this.bar = bar;
    }
}


public interface FooJpaRepository extends JpaRepository<Foo, Long> {

    @Transactional(propagation = Propagation.REQUIRED, readOnly = true)
    List<Foo> findByBar(String bar);
}

此查询在多个地方使用。

我们现在希望在存储到数据库之前对bar的值进行哈希处理,这会增加字段的长度。我将在Foo类中添加一个@PrePersist方法,以在保存之前检查小节的长度。但是,我也想检查findByBar方法中的bar参数的长度,以便在其他地方使用它时,其他开发人员将被警告他们正在使用未哈希值而不是哈希值。

在不创建JpaRepository的实现的情况下有可能吗?

1 个答案:

答案 0 :(得分:3)

如果您使用的是Spring Boot,则可以使用Validation:

https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-validation

首先用@Validate注释存储库,然后在方法参数上使用任何Bean验证注释。

例如:

@Validate
public interface FooJpaRepository extends JpaRepository<Foo, Long> {

    @Transactional(propagation = Propagation.REQUIRED, readOnly = true)
    List<Foo> findByBar(@Size(max = 16) String bar);
}