sql >> Database teknologi >  >> RDS >> Mysql

Hvordan kan vi bruge en af ​​valideringerne i fjederstøvler?

Du skal skrive en brugerdefineret annotation til dette og bruge på klassen

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

Implementering af tilpassede annoteringer

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

Og Validator af brugerdefinerede annoteringer

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. Kan jeg ændre AutoCommit-egenskaben for en JDBC-forbindelse flere gange

  2. Postgresql-forespørgsel mellem datointervaller

  3. Hvordan tilføjer man indledende nul til forskellige char-længder i mysql?

  4. Henter den seneste note (efter tidsstempel) i en enkelt forespørgsel fra en 1:n-tabel