今天在使用Validator框架数据验证的时候碰到了三个类似的注解,都是用来限制长度,但是用法上有区别:

1,@Size和@Length

@Data

public class LoginVo {

@Length(min = 5, max = 17, message = "userName长度须在[5,17]") // 可以为 null,若不为 null,则长度为 [5, 17]

private String userName;

// @Size不能验证Integer,适用于String

@Size(min = 1, max = 3, message = "password长度须在[1,3]")

private String password;

@Size(min = 1,max = 5,message = "list的Size在[1,5]") // list 可以为 null,若不为 null,则长度为 [1, 5]

private List list;

@NotNull

@Valid // 级联校验,该注解将会校验自定义类

private OrderItem detailInfo;

}

 @Size是一个Bean验证注释,用于验证关联的String具有的长度受最小值和最大值限制的值.

 @Length是一个Hibernate特定的注释,与@Size具有相同的含义;

两者的区别:

​ 用@length限制长度为100,@length验证的应该为100个字符的长度,如99个汉字+2个数字,@length并不会报错;

​ 但用@size限制长度为100,同样情况下则会报错,即超出限制长度

​ 综上,@length限制长度为字符长度,@size限制长度为个数长度,@size为限制长度通用格式

2,@Colunm

@Entity

@Data

public class MyEntity {

@Column(name = "MY_FIELD_1", length=13)

private String myField1;

@Column(name = "MY_FIELD_2")

@Size(min = 13, max = 13)

private String myField2;

@Column(name = "MY_FIELD_3")

@Length(min = 13, max = 13)

private String myField3;

}

同样的在实体类当中可以定义@Colunm注解当中设置length属性。这是一个JPA注释,并且length属性由模式生成工具用于设置关联的SQL列长度,与DDL有关

文章链接

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: