18.序列

一、创建默认序列

create sequence myseq;

二、创建含有步长和起始值的序列

create sequence myseq increment by 1 start with 0;

三、使用序列的nextval属性

insert into mydept values(myseq.nextval,'系统软件部');

四、删除序列

drop sequence myseq;

五、修改序列

alter sequence myseq increment by 2;

六、创建表时使用自动序列

6.1 先创建一个表
create table mydept(deptnum number,dname varchar2(20)); 
6.2 为deptnum列创建序列
create sequence deptnum_seq increment by 1 start with 0;
6.3 为该表创建触发器
create or replace trigger mydept_trigger 
before
insert on mydept
for each row
begin
select deptnum_seq.nextval into :New.deptnum from dual;
end;
6.4 插入数据进行验证
insert into mydept (dname) values ('系统软件部');

七、创建表时使用自动序列(oracle 12c以后的版本支持)

create table mydept(deptno number generated by default as identity ( start with 1 increment by 1),dname varchar2(20)); 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值