1、使用MyEclipse生成基于Annotation的实体类与映射
这个过程只和第三章所说的的内容基本相同。这是其中有两个地方得注意的。
注意一:
在通过MyEclipse给项目增加Hibernate功能的时候。我们必须勾上Enable Hibernate Annotations Support。否则在通过MyEclipse生成基于Annotation的实体类时会无法使用这项功能。
注意二:
通过MyEclipse生成实体类和映射的时候,应该选第二项生成基于Annotation的实体类,而不是之前的带.hbm.xml映射文件的实体类。
2、一个简单的Annotation的实体类
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
/**
* @Entity 表示下面的这个User是一个实体类
* @Table 表示映射到数据表中的表名,其中的name参数表示"表名称"
* @Id 表示主键Id,一般放在getXXX前面
*/
@Entity
@Table(name = "user", catalog = "hibernate")
public class User implements java.io.Serializable {
private Integer id;
private String username;
public User() {
}
@Id
@GeneratedValue
@Column(name = "id", unique = true, nullable = false)
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
@Column(name = "username", nullable = false, length = 45)
public String getUsername() {
return this.username;
}
public void setUsername(String username) {
this.username = username;
}
}
3、Annotation的ID生成策略
使用@GeneratedValue(strategy=GenerationType)注解可以定义该标识符的生成策略
Strategy有四个值:
AUTO- 可以是identitycolumn类型,或者sequence类型或者table类型,取决于不同的底层数据库.
相当于native
TABLE- 使用表保存id值
原理:就是在数据库中建立一个表,这个表包含两个字段,一个字段表示名称,另一个字段表示值。每次在添加数据时,使用第一个字段的名称,来取值作为添加数据的ID,然后再给这个值累加一个值再次存入数据库,以便下次取出使用。
IDENTITY- identity column
SEQUENCE- sequence
注意:auto是默认值,也就是说没有后面的参数则表示为auto
4、hibernate.cfg.xml中配置Annotation的实体类
如果是通过MyEclipse生成的实体类的话,这个配置是由工具自动加载到配置文件中的。
<mapping class="cn.framelife.hibernate.entity.User" />
5、AnnotationConfiguration
Annotation方式。在初始化Configuation时,应使用AnnoationConfiguration。这只是用于Application或才测试的时候。如果是Web项目我们还有其它的做法,如整合Spring来使用Spring提供的工具类来调用Hibernate的Api会更加方便。这个我们在说Spring的时候会说到。
Configuration cfg = new AnnotationConfiguration();
cfg.configure();
SessionFactory sessionFactory = cfg.buildSessionFactory();