Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Jak możemy wykorzystać którąś z walidacji w wiosennym bucie?

Musisz napisać do tego własną adnotację i użyć jej na zajęciach

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

Implementacja adnotacji niestandardowych

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

I walidator adnotacji niestandardowych

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. pobrać ostatni wstawiony wiersz od każdego użytkownika w bazie danych

  2. Operacja podzbioru MYSQL

  3. this._callback.apply nie jest funkcją! Błąd Node js Mysql

  4. skrypt do konwersji pliku sql zrzutu mysql do formatu, który można zaimportować do sqlite3 db

  5. Zapytanie hierarchiczne w MySQL. (połącz przez odpowiednik dla MySQL)