sql >> Databáze >  >> RDS >> Mysql

Jak můžeme použít některou z validací v jarním bootování?

K tomu musíte napsat vlastní anotaci a použít ji ve třídě

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

Vlastní implementace anotací

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

A Validátor vlastní anotace

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. MySQL:Průměrný interval mezi záznamy

  2. Mysql - Mysql2::Chyba:Nesprávná hodnota řetězce:

  3. .save vloží do databáze pouze hodnoty null

  4. Jak pomocí Laravel Migration změnit datový typ sloupce a aktualizovat jeho stávající data tak, aby odpovídala novému datovému typu, bez použití nezpracovaných SQL dotazů?