十五、Oracle学习笔记:序列(用于表字段值自增)

一、序列

    1.序列是数据库中为数据表提供的可以自动生成的唯一数值, 通常用来给主键字段赋值。可以递增或者递减。作为主键的字段,通常不人为赋值,需要使用序列自动生成的值。
    2.序列关键字 sequence 序列和表一样,都是数据库中的对象。通常序列为一张表提供主键值。也可以为多张表的主键提供主键值。
    3.序列的创建
        create sequence seqName
        [start with i] -- 从i开始  不指定时默认从1开始
        [increment by j]-- 每次递增或递减j/ 默认递增1, j:为正值时,表示递增为负值时,表示递减
        [maxvalue m|nomaxvalue]--表示最大值m
        [minvalue n|nominvalue]--表示最小值n
        [cycle|nocycle]--表示循环|不循环
        [cache n|nocache]--表示缓存n个数.  默认存储20个数。

--练习:创建序列 seq_emp 从 10000开始,每次增加10,最大值10100,最小值 9900 可循环。
  create sequence seq_emp start with 10000 increment by 10 maxvalue 10100 minvalue 9900 cycle;

    4.序列中的两个伪列。
        nextval:下一个值。
        currval: 当前值,此伪列只有在使用了nextval伪列后,才可以使用。

  select seq_emp.nextval from dual;
  select seq_emp.currval from dual;

二、序列的综合来使用

--练习:创建表 employee 字段empno,number(4) 设计成主键约束,ename,varchar(20),非空约sal,number(9,2)
   drop table employee;
   create table employee (
     empno number(4) primary key,
     ename varchar2(20) not null,
     sal number(9,2)
    );
--创建序列 seq_employee 从1000开始,每次增加1,插入数据,模拟3条
  drop sequence seq_employee;
  create sequence seq_employee start with 1000;

  select seq_employee.nextval from dual;
  select seq_employee.currval from dual;
  insert into employee values(seq_employee.nextval,'张三',3000);
  insert into employee values(seq_employee.nextval,'李四',4000);
  insert into employee values(seq_employee.nextval,'王五',5000);
  commit;
  select * from employee;

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值