利用hibernate实现oracle(每张表的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。
时间: 2024-10-18 06:02:25

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

oracle ORA-01653 表空间不能自动增长的原因及处理方法

背景:表空间已经设置自动增长,但达到一定大小后仍会报ORA-01653. 解决过程: 查阅相关资料,多数只给出了解决办法,但这个解决办法经过验证也是临时了,到了一定大小仍旧会报错,到时只能再次采取同样办法进行操作. 通过几台机器的观察发现,报出该错误时,数据表文件的大小是一致的32G.因此判断,某种原因导致了该限制.于是进行相关搜索,最终找到了答案,但是,对于这一问题描述,有2个说法:1.windows系统下,单文件有32G的限制,但该说法我没有查到有力的支持证据,即便有其他人提到该说法,但并没

设置sde表空间为自动增长

有的用户在测试数据时,希望在SDE表空间里面不受限制地导入数据,于是需要将SDE的表空间设置为自动增长. 过程描述 1.可以在创建sde表空间的时候,添加参数Autoextend on,修改后创建命令如下:create tablespace sde datafile '/LOCATION/sde.dbf' size 140Mextent management local uniform size 512K autoextend on; 2.如果已经创建了表空间,那么可以用下面命令修改:alter

Oracle修改表空间为自动扩展

1.数据文件自动扩展的好处1)不会出现因为没有剩余空间可以利用到数据无法写入2)尽量减少人为的维护3)可以用于重要级别不是很大的数据库中,如测试数据库等 2.数据文件自动扩展的弊端1)如果任其扩大,在数据量不断变大的过程中会导致某个数据文件异常的大2)没有人管理的数据库是非常危险的 3.查询当前数据库中表空间SEC_D是否为自动扩展[email protected]> select tablespace_name,file_name,autoextensible from dba_data_fi

(转)Oracle修改表空间为自动扩展

1.数据文件自动扩展的好处1)不会出现因为没有剩余空间可以利用到数据无法写入2)尽量减少人为的维护3)可以用于重要级别不是很大的数据库中,如测试数据库等 2.数据文件自动扩展的弊端1)如果任其扩大,在数据量不断变大的过程中会导致某个数据文件异常的大2)没有人管理的数据库是非常危险的 3.查询当前数据库中表空间SEC_D是否为自动扩展[email protected]> select tablespace_name,file_name,autoextensible from dba_data_fi

oracle id 自动增长

--创建表 create table abc(id number(4) not null primary key,username varchar2(20) not null,pwd varchar2(20) not null); --创建序列 create sequence abc_sequence increment by 1 start with 1 maxvalue 9999 cycle nocache; --创建触发器 create or replace trigger abc_tri

oracle设置id自动增长

1.创建增长序列 create sequence 序列名 minvalue 1 maxvalue 99999999999999999999 start with 1 increment by 1 nocache 2.创建触发器(关联表字段和序列) create or replace trigger 触发器名 before insert on 表名 for each row begin select 序列名.nextval into:new.表字段 from dual; end;

创建触发器在表中播入数据时ID自动增长

create table ttt (id number primary key ,name varchar2(20),age number(2)) create or replace trigger gger_tt before insert on ttt for each row when (new.id is null) begin select ttt_sequence.nextval into :new.id from dual; end;

Oracle 设置主键Id自增长

--创建序列:CREATE SEQUENCE seq_Grelation -- 尽量使用统一前缀命名,方便管理         INCREMENT BY 1   -- 自增步长 这里设置为1       START WITH 1     -- 计数起点 这里设置为1       NOMAXVALUE       -- 不设置最大值 可选项 MAXVALUE|MINVALUE       NOCYCLE          -- 一直累加,不循环         CACHE 10; --创建触发器:

SQLServer清空数据库中所有的表并且ID自动归0

exec sp_MSforeachtable 'Truncate Table ?'