hbm.xml中的<id>是一个非常重要标签,用于标明POJO和表单中的主键,特别要指出的是标签内部的<generator>标签
generator标签通过class属性告诉DB,id主键的生成方式,共有7种,可大致归为3类:
1、DB生成类
identity 自增长,由数据库自行增长id值,适用于mysql,sqlserver等。
建立数据库时需要说明: 【sql中】 int id identity primary key
sequence 序列,如果数据库支持序列就可以使用,如orcale
native 根据dialect来选择id的增长方式(identity或者是sequence),没有设定dialect时,使用hilo算法。
2、hibernate生成
increment hibernate自增长,根据当前数据库中最大id+1来计算当前实体的id值;这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例访问,此方式必须避免使用。
hilo和uuid 都是通过算法生成,不同的是uuid返回的是128位的字符串
foreign 使用另外一个相关联对象的标识符,由hibernate查找到后生成。
3、程序生成
assigned 让应用程序在保存之前为对象分配一个标识符。
generator标签通过class属性告诉DB,id主键的生成方式,共有7种,可大致归为3类:
1、DB生成类
identity 自增长,由数据库自行增长id值,适用于mysql,sqlserver等。
建立数据库时需要说明: 【sql中】 int id identity primary key
sequence 序列,如果数据库支持序列就可以使用,如orcale
native 根据dialect来选择id的增长方式(identity或者是sequence),没有设定dialect时,使用hilo算法。
2、hibernate生成
increment hibernate自增长,根据当前数据库中最大id+1来计算当前实体的id值;这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例访问,此方式必须避免使用。
hilo和uuid 都是通过算法生成,不同的是uuid返回的是128位的字符串
foreign 使用另外一个相关联对象的标识符,由hibernate查找到后生成。
3、程序生成
assigned 让应用程序在保存之前为对象分配一个标识符。