Hibernate注解配置
在之前的第一次对框架的实际应用中,我使用的是Hibernate的xml配置方法,xml配置方法非常繁琐, 还是推荐所有使用Hibernate的人使用注解方式进行配置,在这篇文章中,我将列举出我们常用的注解配置,下面我将分为下面点进行阐述。
一、类级别注解
二、属性级别注解
三、关联映射关系
一、类级别注解
A)@Entity
@Entity:映射实体类型
@Entity(name=””):指定在数据库中与其对应的表名
在使用@Entity时必须存在主键。
B) @Table(name=””, catalog=””, schema=””)
与@Entity配合使用,name属性代表在数据库中与其对应的表名
Catalog 可选:表示Catalog名称 默认为””
Schema 可选:表示Schema名称 默认为””
C) @Embeddable
从面向对象的角度,表示该类可以被嵌入到其他类中。
从关系型数据库的角度,表示该类中标识的属性会映射成列之后嵌入到其他表中。
在正常的使用下,可以将该注解标识的属性嵌入到其他类中充当属性,但存在一种特殊情况,即该嵌入类充当主键的情况,将在@EmbeddedId进行说明。
二、属性级别注解
A) @Id:映射到数据库中充当主键,该注解可以同时标识多个属性,此时充当联合主键。
若作联合主键使用,该类必须实现serializable接口
String型属性作主键时,必须限定String长度,长度最长不要超过40位,否则会生成主键失败
B) @GeneratedValue(strategy=””, generator=””)
Strategy 可以有四种取值分别是:
GenerationType.AUTO:根据底层数据库自动选择
GenerationType.INDENTITY:根据数据库的Identity字段生成
GenerationType.SEQUENCE:使用Sequence在决定主键的取值
GenerationType.TABLE:使用指定的表决定主键的取值,结合 @TableGenerator使用
Example:
@Id
@TableGenerator(table=”tab_cat_gen”, allocationSize=1)
@GeneratedValue(Strategy=GenerationType.TABLE)
C) @Column
常用属性:
name : 与该属性对应的列的名称
nullable: 与该属性对应的列的值是否可以为null
uinique: 与该属性对应的列的值是否唯一
length:与该属性对应的列的域的长度上限
insertable: 表示在orm框架中插入一条记录时,该字段是否出现在insert语 句中。
updateable: 表示在orm框架中更新一条记录时,该字段是否出现在insert语 句中。
D) @Embedded 与 @EmbeddedId
被标识该注解的属性代表该属性的类是一个嵌入类,同时,该嵌入类必须带有 @Embeddable注解
当该属性被 标识为主键时,必须标识为@EmbeddedId,并且同时满足下面几个条件:
1实现Serializable接口
2有磨人的public的无参构造方法。
3实现equals() 和 HashCode() 方法。
E) @Transient:
该注解 该属性并不是一个映射倒数据库表的字段属性,ORM框架将会忽略该属性。
三、关系映射注解
A)单向一对一外键关联
设存在A、B双方存在一对一关系
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name=””,unique=true)
其中A方标识上以上注解,name属性代表着与其对应的B方的列名
如果B方使用@Column重新指定了列名,该name应该指向修改过后的名字
B) 双向一对一外键关联
在a)的基础上,同时给B方加上以下注解
@OneToOne(mappedBy=””)
mappedBy指向A方的属性变量名
C) 单向多对一外键关联
设A方维护多的关系,B方维护一的关系
需要从A方到B方的多对一的单向关联关系
@ManyToOne(cascade={CascadeType.ALL}, fetch=FetchType.EAGER)
@JoinColumn(name="")
本质是需要在A方维护一个外键
只需要在A方配置以上注解,fetch属性代表对该属性的获取策略,作为多的一方, 需要积极(eager)地获取以节省资源。
@JoinColumn(name=””)中name属性代表要参照的列名,而非属性名。
D) 单向一对多外键关联
@OneToMany(cascade={CascadeType.ALL}, fetch=FetchType.LAZY)
@JoinColumn(name="")
一对多在数据库中的体现形式与多对一在数据库中的体现形式一样,都是需要在多的 一方中维护一个参照一的一方的一个外键,但是不同的是,我们需要通过配置注解, 使得我们可以使用一的一方的对象获取到一个(多的一方)的集合
作为一的一方,我们需要使用延迟加载技术(fetch=FetchType.LAZY),否则时 时刻刻都要对持有的集合进行维护,十分损耗服务器资源。
E) 双向一对多外键关联
双向一对多外键关联 = 单向一对多外键关联 + 单向多对一外键关联
只需要把这两种的配置迭加即可
F) 单向多对多外键关联
首先需要说明的是,我们在前面使用的几种关联关系中,我们都只要直接的使用双方 对应的两个表就足够我们完成对关系的维护。
但是在多对多的两种关系中,我们无法使用两个表,而是需要一个中间表来维护两个 表之间的多对多的关系
多对多的关系重点就是在指定中间表。
假设A、B双方存在多对多的关系:
只需要A、B中任意一方标识以下注解:
@ManyToMany
@JoinTable(
name="",
joinColumns={@JoinColumn(name="")},
inverseJoinColumns={@JoinColumn(name=""),
@JoinColumn(name=""),
@JoinColumn(name=""),
@JoinColumn(name="")}
)
@JoinTable用于标识中间表
name 表示表名
joinColumns 和inverseJoinColumn中可以指定对应的的外键列名,如果A、B 中存在联合主键,只需要指定多个@JoinColumn即可。
G) 双向多对多外键关联
双向多对多的外键关联只需要在单向的基础上,在B方加上一下注解(假设A方已经 维护好单向多对多关系):
@ManyToMany(mappedBy="")
mappedBy指向在A方中的变量属性名即可。