您的位置:首页 > 其它

初学Hibernate主键生成策略

2015-08-15 23:42 621 查看
  具有业务含义的主键叫自然主键;随机生成,不具备业务含义的字段作为主键,叫代理主键。

在表与POJO类关系映射文件XXX.hbm.xml中,可通过配置id元素下generator节点的class属性指定数据表主键生成策略<generator class="生成策略"></generator>;所谓主键生成策略就是hibernate怎样管理表的主键

主键生成策略:1~4自动增长(1、2、3······),代理主键;5主键为字符串,代理主键;6一般用于自然主键,需要在程序里指定主键值,无法自动生成

  1、increment;代表主键是自动增长的,是由hibernate本身来管理。

          注意:数据库要支持自动增长,如MySQL,SQLserver;Oracle不可以;在多线程情况下,可能会产生主键冲突问题

  2、identity;由底层数据库生成,不由hibernate本身来管理

          注意:数据库支持自动增长,如MySQL,SQLserver;Oracle不可以;   

  3、sequence;标识符生成器利用底层数据库提供的序列来生成标识符

          注意:数据库支持序列,和hibernate程序无关,如Oracle支持,而MySQL就不可以;如Oracle数据库有序列customer_seq,则配置如:<generator class="sequence">customer_seq</generator>

  4、native;标识符依据底层数据库对自动生成标识符的支持能力,来选择使用identity,sequence,或hilo标识符生成器,如MySQL自动选择identity,Oracle自动选择sequence

  5、uuid;主键是字符串的可以用uuid来处理,随机产生32字符串

  6、assigned;一般用于自然主键,无法自动生成,需要程序指定值

  7、复合主键;需要在配置文件里指定复合主键id;如有Person类和Person表,Person表有复合主键firstName和secondName,和age字段

<hibernate-mapping>
<!-- 类与表关系,name类全名称,table表名 -->
<class name="cn.hjp.domain.Person" table="Person">
<!-- 复合主键 -->
<composite-id>
<key-property name="firstName"></key-property>
<key-property name="secondName"></key-property>
</composite-id>
<property name="age" column="age" type="int"></property>
</class>
</hibernate-mapping>


    注意:Person类必须实现序列化接口Serializable
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: