Проверьте минимальную длину параметра в Spring Jpa Query - PullRequest
0 голосов
/ 29 января 2019

У нас есть объект данных Foo, который имеет строковое свойство Bar, и репозиторий jpa с методом поиска Foo by Bar:

@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);
}

Этот запрос используется в нескольких местах.

Теперь мы собираемся хэшировать значение бара перед сохранением в базу данных, что увеличивает длину поля.Я собираюсь добавить метод @PrePersist в класс Foo, чтобы проверить длину полосы перед ее сохранением.Однако я также хочу проверить длину параметра bar в методе findByBar, чтобы при его использовании в другом месте другие разработчики были предупреждены о том, что они используют не хэшированное значение вместо хэшированного значения.

Возможно ли это без создания реализации JpaRepository?

1 Ответ

0 голосов
/ 29 января 2019

Если вы используете Spring Boot, вы можете использовать Validation:

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

Сначала аннотируйте репо с помощью @Validate, а затем используйте любые аннотации Bean Validation для параметров метода.

Например:

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

    @Transactional(propagation = Propagation.REQUIRED, readOnly = true)
    List<Foo> findByBar(@Size(max = 16) String bar);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...