利用hibernate实现oracle(每张表的ID)自动增长

本文详细介绍了如何在Hibernate映射文件中设置ID的增长策略为sequence,并通过配置指定sequence名字来实现数据库表中唯一ID的高效生成。通过这种方式,避免了传统方法中使用触发器生成ID的复杂性,简化了数据库操作。

设置ID的增长策略是sequence,同时指定sequence的名字,最好每个表建一个sequence
 例如创建一个序列:
CREATE SEQUENCE DEPARTMENT_ID_SEQ MINVALUE 10000 MAXVALUE 999999999999999999999999 INCREMENT BY 1 NOCYCLE;
 hibernate映射文件的配置:

  • <?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> 
    在 hibernate映射文件中,对ID的生成策略选择sequence,指定sequence的名字DEPARTMENT_ID_SEQ就可以了,当你保 存新对象的时候,hibernate会自动取得DEPARTMENT_ID_SEQ.NEXTVAL作为新对象的ID保存到数据库,所以不需要再使用触发 器再来生成新记录的ID。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值