浅谈定制Hibernate映射

在向大家详细介绍定制Hibernate映射之前,首先让大家了解下Hibernate自动生成主键,然后全面介绍定制Hibernate映射。

Hibernate 能够出色地自动生成主键。Hibernate/EBJ 3 注释也可以为主键的自动生成提供丰富的支持,允许实现各种策略。下面的示例说明了一种常用的方法,其中Hibernate将会根据底层数据库来确定一种恰当的键生成策略:

public Long getId() {  


return id;  


}  

定制Hibernate映射

默认情况下,Hibernate会将持久类以匹配的名称映射到表和字段中。例如,前一个类可以与映射到以如下代码创建的表中:

CREATE TABLE MODELPLANE   


(  


ID long,  


NAME varchar  


) 

如果您是自己生成并维护数据库,那么这种方法很有效,通过省略代码可以大大简化代码维护。然而,这并不能满足所有人的需求。有些应用程序需要访问外部数据库,而另一些可能需要遵从公司的数据库命名惯例。如果有必要,您可以使用 @Table 和 @Column 注释来定制您自己的持久性映射,如下所示:

public class ModelPlane {  


private Long id;  


private String name;  


@Id  



@Column(name="PLANE_ID")  



public Long getId() {  


return id;  


}  


public void setId(Long id) {  



this.id = id;  



}  



@Column(name="PLANE_NAME")   



public String getName() {  


return name;  


}  


public void setName(String name) {  



this.name = name;  



}  


}  

该内容将映射到下表中:

CREATE TABLE T_MODEL_PLANE   


(  


PLANE_ID long,  


PLANE_NAME varchar  


)  

相关推荐