欢迎转载,请注明出处http://www.cnblogs.com/shizhongtao/p/3436523.html
一、xml配置方式的id生成
<id name="id" >
<generator class="native"></generator>
</id>
其中class常用的值有四个,native、 identity、 sequence、 uuid。
注:其中native和uuid不局限与数据库。如果用oracle的话。使用native,就会在数据库中使用sequence来自动生成id;在mysql中。会设置id auto_increatment(代表id自动增长)
“uuid.hex” : 由 Hibernate 基于128 位 UUID 算法 生成16 进制数值(编码后以长度32 的字符串表示)作为主键。
“uuid.string” : 与uuid.hex 类似,只是生成的主键未进行编码(长度16),不能应用在 PostgreSQL 数据库中。
二、注解(anotation)方式
- auto方式在主键id上标注,@GeneratedValue
(@GeneratedValue(strategy=GenerationType.AUTO)) 默认:对 MySQL,使用auto_increment
对 Oracle使用hibernate_sequence(名称固定) - 使用IDENTITY(@GeneratedValue(strategy=GenerationType.IDENTITY)
使用于sql server,mysql数据库中,oracle不适用
- SEQUENCE(@GeneratedValue(strategy=GenerationType.SEQUENCE))(在oracle中使用)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "teacherSEQ")
public class Teacher
{
private int id;
private String name;@SequenceGenerator(name="teacherSEQ", sequenceName="teacherSEQ_DB")
public int getId()
{
return id;
}
public void setId(int id)
{
this.id = id;
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
} - 使用uuid方式,和上面的sequence的方式类似
@Id
@GenericGenerator(name = "system-uuid", strategy = "uuid.hex")
@GeneratedValue(generator = "system-uuid")
public String getId() {
return id;
} - 使用table方式,待续……