Hibernate注解

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Hibernate注解

常用的hibernate annotation标签如下:

@Entity

--注释声明该类为持久类。

@Table(name="promotion_info")

--持久性映射的表(表名="promotion_info)。

@Column(name=”DESC”,nullable=false,length=512)

--用于指定持久属性或字段的映射列。

@Id

--注释可以表明哪种属性是该类中的独特标识符(即相当于数据表的主键)。

@GeneratedValue

--定义自动增长的主键的生成策略。

@Transient

--将忽略这些字段和属性,不用持久化到数据库。

@Temporal(TemporalType.TIMESTAMP)

--声明时间格式。

@Enumerated

--声明枚举

@Version

--声明添加对乐观锁定的支持

@OneToOne

--可以建立实体bean之间的一对一的关联

@OneToMany

--可以建立实体bean之间的一对多的关联

@ManyToOne

--可以建立实体bean之间的多对一的关联

@ManyToMany

--可以建立实体bean之间的多对多的关联

@Formula

--一个SQL表达式,这种属性是只读的,不在数据库生成属性(可以使用sum、average、max等)

@OrderBy

--Many端某个字段排序(List)

下面是对以上常用Hibernate注解标签的详细介绍与举例:

@Entity

--注释声明该类为持久类。将一个Javabean类声明为一个实体的数据库表映射类,最好实现序列化.此时,默认情况下,所有的类属性都为映射到数据表的持久性字段.若在类中,添加另外属性,而非映射来数据库的, 要用下面的Transient来注解.

@Table(name="promotion_info")

--持久性映射的表(表名="promotion_info).@T able是类一级的注解,定义在@Entity下,

为实体bean映射表,目录和schema的名字,默认为实体bean的类名,不带包名.

示例:

@Entity

@T able(name="CUST", schema="RECORDS")

public class Customer { ... }

@Column(name=”DESC”,nullable=false,length=512)

--用于指定持久属性或字段的映射列。如果没有指定Column 注释,则应用默认值。

该注释下的一些具体属性如下:

①unique属性表示该字段是否为唯一标识,默认为false。如果表中有一个字段需要唯一标识,则既可以使用该标记,也可以使用@T able标记中的@UniqueConstraint。

②nullable属性表示该字段是否可以为null值,默认为true。

③insertable属性表示在使用“INSERT”脚本插入数据时,是否需要插入该字段的值。

④updatable属性表示在使用“UPDATE”脚本插入数据时,是否需要更新该字段的值。insertable和updatable属性一般多用于只读的属性,例如主键和外键等。这些字段的值通常是自动生成的。

⑤columnDefinition属性表示创建表时,该字段创建的SQL语句,一般用于通过Entity 生成表定义时使用。

⑥table属性表示当映射多个表时,指定表的表中的字段。默认值为主表的表名。

⑦length属性表示字段的长度,当字段的类型为varchar时,该属性才有效,默认为255个字符。

⑧precision属性和scale属性表示精度,当字段类型为double时,precision表示数值的总长度,scale表示小数点所占的位数。

示例1:

@Column(name="DESC", nullable=false, length=512)

public String getDescription() { return description; }

示例2:

@Column(name="DESC",columnDefinition="CLOB

NOT NULL",table="EMP_DETAIL")

@Lob

public String getDescription() {

return description;

}

示例3:

@Column(name="ORDER_COST", updatable=false, precision=12, scale=2)

public BigDecimal getCost() { return cost; }

@Id

--注释可以表明哪种属性是该类中的独特标识符(即相当于数据表的主键)。

示例:

@Id

public Long getId() { return id; }

@GeneratedValue

--定义自动增长的主键的生成策略.

示例1:

@Id

@GeneratedValue(strategy=SEQUENCE,

generator="CUST_SEQ")

@Column(name="CUST_ID")

public Long getId() { return id; }

示例2:

@Id

@GeneratedValue(strategy=TABLE,

generator="CUST_GEN")

@Column(name="CUST_ID")

Long id;

@Transient

--将忽略这些字段和属性,不用持久化到数据库.适用于,在当前的持久类中,某些属性不是用于映射到数据表,而是用于其它的业务逻辑需要,这时,须将这些属性进行transient的注解.否则系统会因映射不到数据表相应字段而出错.

示例:

@Entity

public class Employee {

@Id int id;

@Transient User currentUser;

...

}

@Temporal(TemporalType.TIMESTAMP)

--声明时间格式

示例:

@Temporal(DATE)

protected java.util.Date endDate;

@Enumerated

--声明枚举

示例:

public enum EmployeeStatus {FULL_TIME, PART_TIME, CONTRACT}

public enum SalaryRate {JUNIOR, SENIOR, MANAGER, EXECUTIVE}

@Entity public class Employee {

public EmployeeStatus getStatus() {...}

@Enumerated(STRING)

public SalaryRate getPayScale() {...}

...

}

@Version

--声明添加对乐观锁定的支持

示例:

相关文档
最新文档