在 Spring Jpa Query 中验证参数的最小长度

我们有一个数据对象 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 的值进行哈希处理,这会增加字段的长度。我将@PrePersist在 Foo 类中添加一个方法来检查 bar 的长度,然后再保存它。但是,我还想检查findByBar方法中 bar 参数的长度,以便当在其他地方使用它时,其他开发人员会被提醒他们使用的是未散列值而不是散列值。


如果不创建 JpaRepository 的实现,这可能吗?


喵喔喔
浏览 126回答 1
1回答

莫回无

如果您使用的是 Spring Boot,则可以使用验证:https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-validation首先使用 @Validate 对 repo 进行注释,然后在方法参数上使用任何 Bean Validation Annotation。例如:@Validatepublic interface FooJpaRepository extends JpaRepository<Foo, Long> {&nbsp; &nbsp; @Transactional(propagation = Propagation.REQUIRED, readOnly = true)&nbsp; &nbsp; List<Foo> findByBar(@Size(max = 16) String bar);}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java