gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 07:42:36 30 4
gpt4 key购买 nike

我们有一个具有字符串属性 Bar 的数据对象 Foo,以及一个具有通过 Bar 查找 Foo 的方法的 jpa 存储库:

@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 方法以在保存之前检查 bar 的长度。但是,我还想检查 findByBar 方法中 bar 参数的长度,以便在其他地方使用它时,其他开发人员会被提醒他们使用的是未散列值而不是哈希值。

这是否可以在不创建 JpaRepository 实现的情况下实现?

最佳答案

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

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

首先用@Validate 注释repo,然后在方法参数上使用任何Bean Validation Annotation。

例如:

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

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

关于java - 验证 Spring Jpa 查询中参数的最小长度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54417388/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com