Mysql
 sql >> база данни >  >> RDS >> Mysql

Как можем да използваме което и да е от валидирането при пролетно зареждане?

Трябва да напишете персонализирана анотация за това и да я използвате в клас

@AtLeastOneNotEmpty(fields = {"name", "phone"})
public class User{

Внедряване на персонализирани пояснения

@Constraint(validatedBy = AtLeastOneNotEmptyValidator.class)
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface AtLeastOneNotEmpty {

  String message() default "At least one cannot be null";

  String[] fields();

  Class<?>[] groups() default {};

  Class<? extends Payload>[] payload() default {};
}

И Валидатор на персонализирана анотация

public class AtLeastOneNotEmptyValidator
    implements ConstraintValidator<AtLeastOneNotEmpty, Object> {

  private String[] fields;

  public void initialize(AtLeastOneNotEmpty constraintAnnotation) {
    this.fields = constraintAnnotation.fields();
  }

  public boolean isValid(Object value, ConstraintValidatorContext context) {

    List<String> fieldValues = new ArrayList<String>();

    for (String field : fields) {
      Object propertyValue = new BeanWrapperImpl(value).getPropertyValue(field);
      if (ObjectUtils.isEmpty(propertyValue)) {
        fieldValues.add(null);
      } else {
        fieldValues.add(propertyValue.toString());
      }
    }
    return fieldValues.stream().anyMatch(fieldValue -> fieldValue!= null);
  }
}


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Каква библиотека на python 3 трябва да използвам за MySQL?

  2. Извикайте pusher, когато mysql се промени

  3. Хибернация Не може да добави или актуализира дъщерен ред:ограничение за външен ключ е неуспешно

  4. Как мога да задам формат за автоматично увеличение на 0001 в MySQL?

  5. Показване на съдържанието на mysql редове в html таблица с помощта на php