度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 267|回复: 8

[分享] oracle 序列的创建与使用

[复制链接]

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
发表于 2018-6-8 17:50:02 | 显示全部楼层 |阅读模式
在Oracle中,可以使用序列自动生成一个整数序列,主要用来自动为表中的数据类型的主键列提供有序的唯一值,这样就可以避免在向表中添加数据时,手工指定主键值。而且使用手工指定主键值这种方式时,由于主键值不允许重复,因此它要求操作人员在指定主键值时自己判断新添加的值是否已经存在,这很显然是不可取的。
(1)创建序列
序列与视图一样,并不占用实际的存储空间,只是在数据字典中保存它的定义信息。创建序列需要使用CREATE SEQUENCE语句,其语法如下:
CREATE SEQUENCE [schema]。sequence_name  --序列名
[ START WITH start_number ]  --开始数字
[ INCREMENT BY increment_number ]  --每次加几
[ MINVALUE minvalue | NOMINVALUE ]  --最小值
[ MAXVALUE maxvalue | NOMAXVALUE ]  --最大值
[ CACHE cache_number | NOCACHE ]  
[ CYCLE | NOCYCLE ]  --是否循环
[ ORDER | NOORDER ];  
注意:cache参数指定内存预分配的序列数的个数,默认20个,为了加快访问速度。
      order参数指定是否按照请求次序生成序列号,一般使用序列生成主键值时,影响不大。
(2)序列中的两个伪列
Currval:用于获取序列的当前值,必须再使用nextval一次之后才能使用。
nextval:用于获取序列的下一个值,第一次使用返回的是初始值,向表中的主键赋值的时候使用此伪列。
(3)序列举例
  • 首先创建student表:
    create table student(
    sid number(4) primary key,
    sname varchar2(8) not null
    );
  • 创建student_seq序列
    create sequence student_seq
    start with 1
    increment by 1
    nocache nocycle order;
  • 创建触发器(使用student_seq序列)


     create trigger tr_student
    before insert on student
    for each row
    begin
    select student_seq into :new.sid from dual;
    end;
  • 插入数据:
    SQL> insert into student(sname) values('zhang')
    已创建 1 行。
    SQL> insert into student(sname) values('li');
    已创建 1 行。
    SQL> insert into student(sname) values('wang')
    已创建 1 行。
  • 查询数据:
  • SQL> select * from student;
  •        SID SNAME
    ---------- --------
            1  zhang
            2  li
            3  wang


回复

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-6-8 17:50:28 | 显示全部楼层
回复 支持 反对

使用道具 举报

542

主题

5919

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
发表于 2018-6-9 15:39:59 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-6-9 17:55:28 | 显示全部楼层
回复 支持 反对

使用道具 举报

542

主题

5919

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
发表于 2018-6-10 17:04:22 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-6-10 17:58:29 | 显示全部楼层
回复 支持 反对

使用道具 举报

542

主题

5919

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
发表于 2018-6-11 15:09:24 | 显示全部楼层
回复 支持 反对

使用道具 举报

231

主题

2541

帖子

5807

积分

论坛元老

Rank: 8Rank: 8

积分
5807
 楼主| 发表于 2018-6-11 18:00:43 | 显示全部楼层
回复 支持 反对

使用道具 举报

542

主题

5919

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
发表于 2018-6-12 16:58:47 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2018-12-13 07:30 , Processed in 0.435749 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表