在开始讲解Oracle序列使用方法之前,先加一点关于Oracle client sqlplus的使用,就是如果执行多行语句的话一定要加“/”才能表示结束,并执行!本篇文章的主题是通过创建Oracle序列和触发器实现表的主键自增。
1.首先创建序列,Oracle序列的语法格式为:create SEQUENCE 序列名[INCREMENT BY n][START WITH n][{MAXVALUE/ MINVALUE n|NOMAXVALUE}][{CYCLE|NOCYCLE}][{CACHE n|NOCACHE}];
1)INCREMENT BY用于定义序列的步长,如果省略,则默认为1,如果出现负值,则代表Oracle序列的值是按照此步长递减的。
2)START WITH 定义序列的初始值(即产生的***个值),默认为1。

3)MAXVALUE 定义序列生成器能产生的***值。选项NOMAXVALUE是默认选项,代表没有***值定义,这时对于递增Oracle序列,系统能够产生的***值是10的27次方;对于递减序列,***值是-1。
4)MINVALUE定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是?10的26次方;对于递增序列,最小值是1。
5)CYCLE和NOCYCLE 表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到***值时,循环到最小值;对于递减序列达到最小值时,循环到***值。如果不循环,达到限制值后,继续产生新值就会发生错误。
6)CACHE(缓冲)定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。
2.删除Oracle序列的语法是DROP SEQUENCE 序列名;
假设有表TEST,其主键为TEST_ID1)建立递增序列SEQ_TEST:create sequence SEQ_TESTincrement by 1start with 1minvalue 1 nomaxvaluenocylce
2)建立触发器,当有数据插入表TEST时,使用Oracle序列为其去的递增的主键值create trigger TRG_TEST before insert on TESTfor each rowbeginselect SEQ_TEST.nextval into :new.TEST_ID from dual;end;
至此,创建完成!
当然也可以不使用触发器,而是在插入时在SQL语句中调用序列,例如insert into TEST values(SEQ_TEST.nextval, ……) ;
【编辑推荐】
oracle数据库中有哪些字符集,字符集之间的子集和超集关系是怎么样的?
oracle数据库的字符集有很多的,具体的也不能一一详细地列举出来了,但是,建库的时候,会有选择字符集的界面,点开下拉条,将会列出oracle所支持的所有字符集(10/12)。 超集与子集是包含和被包含的关系,超集兼容子集。
oracle表中怎么建序列
oracle表中创建序列语法:CREATE SEQUENCE name[INCREMENT BY n][START WITH n][{MAXVALUE n | NOMAXVALUE}][{MINVALUE n | NOMINVALUE}][{CYCLE | NOCYCLE}][{CACHE n | NOCACHE}]示例:increment by n:表明值每次增长n(步长)。 start with n: 从n开始。 {MAXVALUE n | NOMAXVALUE}: 设置最大值。 {MINVALUE n | NOMINVALUE}: 设置最小值,start with不能小于最小值。 CYCLE | NOCYCLE : 是否循环,建议不使用CACHE n | NOCACHE: 是否启用缓存。 2、插入数据到表中示例:INSERT INTO emp VALUES(emp_sequence , LEWIS, CLERK,7902, SYSDATE, 1200, NULL, 20);Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。 它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。 ORACLE数据库是目前世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。 扩展资料:sql server数据库里建序列:alter table cust_infoaddsequence intinsert into cust_info (sequence)select row_number() over(orderbycust_id) as cust_id_seq from cust_info
详解Oracle DELETE和TRUNCATE 的区别
展开全部语法delete from aa truncate table aa 区别 from后面可以写条件,truncate不可以。 from记录是一条条删的,所删除的每行记录都会进日志,而truncate一次性删掉整个页,因此日至里面只记录页释放,简言之,delete from更新日志,truncate基本不,所用的事务日志空间较少。 from删空表后,会保留一个空的页,truncate在表中不会留有任何页。 4.当使用行锁执行 DELETE 语句时,将锁定表中各行以便删除。 truncate始终锁定表和页,而不是锁定各行。 5.如果有identity产生的自增id列,delete from后仍然从上次的数开始增加,即种子不变,而truncate后,种子会恢复初始。 不会触发delete的触发器,因为truncate操作不记录各个行删除。 总结和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态。 语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger。 语句不影响表所占用的extent, 高水线(high watermark)保持原位置不动 显然drop语句将表所占用的空间全部释放 truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始)。 4.速度,一般来说: drop> truncate > delete。 5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及。 6.使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大. 想删除表,当然用drop 想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。
发表评论