目录
导读
Java 注解(Annotation)又称 Java 标注,是 JDK5.0 引入的一种注释机制。Java 语言中的类、方法、变量、参数和包等都可以被标注。和 Javadoc 不同,Java 标注可以通过反射获取标注内容。在编译器生成类文件时,标注可以被嵌入到字节码中。Java 虚拟机可以保留标注内容,在运行时可以获取到标注内容 。 当然它也支持自定义 Java 标注。
@Column标记表示所持久化属性所映射表中的字段
@Target(value={METHOD,FIELD})
@Retention(value=RUNTIME)
public @interface Column
Specifies the mapped column for a persistent property or field. If no Column annotation is specified, the default values apply.
Example 1:
@Column(name="DESC", nullable=false, length=512)
public String getDescription() { return description; }
Example 2:
@Column(name="DESC",
columnDefinition="CLOB NOT NULL",
table="EMP_DETAIL")
@Lob
public String getDescription() { return description; }
Example 3:
@Column(name="ORDER_COST", updatable=false, precision=12, scale=2)
public BigDecimal getCost() { return cost; }
是什么?
@Target({METHOD, FIELD}) @Retention(RUNTIME)
public @interface Column {
String name() default "";
boolean unique() default false;
boolean nullable() default true;
boolean insertable() default true;
boolean updatable() default true;
String columnDefinition() default "";
String table() default "";
int length() default 255;
int precision() default 0;
int scale() default 0;
}
@Column属性详解:@Column注解一共有10个属性,这10个属性均为可选属性
name
name属性定义了被标注字段在数据库表中所对应字段的名称;unique
unique属性表示该字段是否为唯一标识,默认为false。如果表中有一个字段需要唯一标识,则既可以使用该标记,也可以使用@Table标记中的@UniqueConstraint。nullable
nullable属性表示该字段是否可以为null值,默认为true。insertable
insertable属性表示在使用“INSERT”脚本插入数据时,是否需要插入该字段的值。updatable
updatable属性表示在使用“UPDATE”脚本插入数据时,是否需要更新该字段的值。insertable和updatable属性一般多用于只读的属性,例如主键和外键等。这些字段的值通常是自动生成的。columnDefinition
columnDefinition属性表示创建表时,该字段创建的SQL语句,一般用于通过Entity生成表定义时使用。(也就是说,如果DB中表已经建好,该属性没有必要使用。)table
table属性定义了包含当前字段的表名。length
length属性表示字段的长度,当字段的类型为varchar时,该属性才有效,默认为255个字符。precision和scale
precision属性和scale属性表示精度,当字段类型为double时,precision表示数值的总长度,scale表示小数点所占的位数。
@Column可以标注在属性前或getter方法前;
总结
以上就是今天要讲的内容,本文系统介绍了@Column属性注解
参考文章:http://docs.oracle.com/javaee/5/api/javax/persistence/Column.html