2

为了获得最佳性能和验证便利,String 字段需要哪些注释?

数据库:MySQL

存储地区名称的字段

@Column(length=50)  // javax.persistence.Column

这将被转换为 varchar(50) 吗?或者我特别需要这个:

@Column(columnDefinition='varchar(50)') 

还有两个注释

@MaxLength(50) // play.data.validation.Constraints.MaxLength
@Length(max=50) // com.avaje.ebean.validation.Length, is this one useful or not required anyway?
public String districtName;

我想我需要@Column(length=50) 进行定义和@MaxLength(50) 进行验证?或者这两个中的一个会自动暗示另一个?

谢谢。

4

1 回答 1

6

据我所知,当我们String用这些注释标记变量时:

  1. @javax.persistence.Column(length=50)
  2. @javax.persistence.Column(columnDefinition='varchar(50)'). 注意:我使用的是 postgreSQL,这将创建具有不同数据类型的列定义
  3. @com.avaje.ebean.validation.Length(50)

上面的三个注释具有相同的目的。这些将在数据库上创建具有character varying数据类型和50字符长度的列定义。

如果没有@Constraint.MaxLength(50),当您输入长度大于 50 的输入值时,您将得到如下异常:

执行异常 [ValidationException: validation failed for: models.TheModel]

我认为,应该有一种方法来处理上述异常,但老实说,直到现在我才知道该怎么做。


建议

我对您的建议是使用 anotation 从上面的 3 个注释中选择一个(这是您的偏好)@Constraint.MaxLength(50)。对我来说,这是最简单最简单的方法,你可以使用 play framework scala-template-helper 轻松制作表单。

于 2013-04-23T09:19:49.737 回答