【09】序列

在许多的数据表之中都存在一种称为自动增长列的操作,但是在 Oracle 之中,这种自动增长
列并不是自动控制的, 而是需要用户手工的控制,这样做主要是为了开发方便,

创建序列的语法如下:

    create sequence sequence_name
    [{minvalue n | NOMINVALUE}]
    [{maxvalue n | NOMAXVALUE}]
    [start with n]
    [increment by n]
    [{CYCLE | NOCYCLE}]
    [{CACHE n | NOCACHE}];

创建序列

	CREATE SEQUENCE my_seq start with 1 increment by 1;

当一个序列创建完之后,可以通过以下两种方式访问序列:

  • 序列名称.nextval:让序列增长到下一个内容;
  • 序列名称.currval:取得当前序列的内容;
    SELECT my_seq.currval from dual;
  • 在 Oracle 之中, 如果想要操作 currval,则首先必须先使用 nextval;

    SELECT my_seq.nextval from dual;
    SELECT my_seq.currval from dual;
    
  • 序列一般都作为主键使用,例如,下面定义一张表:

    DROP TABLE mvtab PURGE;
    CREATE TABLE mytab(
      id number PRIMARY KEY,
      name varchar2(50) NOT NULL
    )
    
  • 现在向 mvtab 表中增加数据:

    INSERT INTO mytab(id,name) VALUES(my_seq.nextval,’ 张晓倩’);
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值