hibernate oracle ID自动增长的实现

hibernate oracle ID自动增长的实现

 

 

 根据hibernate的文档,有两种方式实现实体对象的主键自动增长。 

第一种:设置ID的增长策略是sequence,同时指定sequence的名字,最好每个表建一个sequence,此种做法就如同MS-SQL,MY-SQL中的自动增长一样,不需要创建触发器

 

<?xml version="1.0"?>   
<!DOCTYPE hibernate-mapping PUBLIC   
      "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
          "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">   
<hibernate-mapping package="com.liyanframework.demo.domain">   
    <class name="Department" table="DEPARTMENT">   
        <id name="id" column="ID">   
            <generator class="sequence">   
                <param name="sequence">DEPARTMENT_ID_SEQ</param>   
            </generator>   
        </id>   
        <property name="name" column="NAME" type="string" />   
        <property name="description" column="DESCRIPTION" type="text" />   
    </class>   
</hibernate-mapping>

 

 

第二种:设置ID的增长策略是native,但是需要创建一个名字为hibernate_sequence(这个名字好像是hibernate默认的 sequence名字,不创建会出错的)的全局使用的sequence,然后再对每一个表的ID生成的时候,使用触发器,取得 hibernate_sequence.CURRVAL作为新记录的ID,

 

<?xml version="1.0"?>   
<!DOCTYPE hibernate-mapping PUBLIC   
      "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
          "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">   
<hibernate-mapping package="com.liyanframework.demo.domain">   
    <class name="Department" table="DEPARTMENT">   
        <id name="id" column="ID">   
            <generator class="native">                     
            </generator>   
        </id>   
        <property name="name" column="NAME" type="string" />   
        <property name="description" column="DESCRIPTION" type="text" />   
    </class>   
</hibernate-mapping>

 

比较两种做法,第一种做法也就是hibernate在代码中,实现了oracle中的触发器功能。对于不同的情况,选择不懂的做法。如果新的系统,新建的 oracle数据库,推荐使用第一种做法,简单,容易移植到其他支持自动增长的数据库;如果是老的系统,需要把其他数据库转换为oracle的,那就要用第二种了,使用native的方式,可以不改动配置文件,兼容oracle和mysql之类带有自动增长的数据库。

转载于:https://www.cnblogs.com/andyboy/archive/2013/05/29/3107015.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值