Oracle 向表插入数据时,ORACLE sequence的使用

    

在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。   1、Create Sequence   你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,   CREATE SEQUENCE emp_sequence   INCREMENT BY 1 -- 每次加几个   START WITH 1 -- 从1开始计数   NOMAXVALUE -- 不设置最大值   NOCYCLE -- 一直累加,不循环   CACHE 10;     一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL   CURRVAL=返回 sequence的当前值   NEXTVAL=增加sequence的值,然后返回 sequence 值   比如:   emp_sequence.CURRVAL   emp_sequence.NEXTVAL     可以使用sequence的地方:   - 不包含子查询、snapshot、VIEW的 SELECT 语句   - INSERT语句的子查询中   - NSERT语句的VALUES中   - UPDATE 的 SET中     可以看如下例子:   INSERT INTO emp VALUES   (empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20);     SELECT empseq.currval FROM DUAL;     但是要注意的是:   - 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?     - 如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。     2、Alter Sequence   你或者是该sequence的owner,或者有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence 再 re-create .   Alter sequence 的例子   ALTER SEQUENCE emp_sequence   INCREMENT BY 10   MAXVALUE 10000   CYCLE -- 到10000后从头开始   NOCACHE ;       影响Sequence的初始化参数:   SEQUENCE_CACHE_ENTRIES =设置能同时被cache的sequence数目。     可以很简单的Drop Sequence   DROP SEQUENCE order_seq;
 
————————————————————华丽的分界线————————————————————————
下面就是我自己实现的语句了:

insert into tlm_packlist_item (pi_id,pack_no,orderid,order_itemno,partid,partserid,pn,sn,bn,from_std,pn_description,qty)

(select tlm_packlist_item_seq.nextval,'K201111055',
       o.orderid,
       m.req_itemno,
       p.partid,
       s.partserid,
       trim(p.pn),
       trim(s.sn),
       trim(b.bn),
       trim(st.station),
       trim(p.description),
       (b.reserved_qty - (select nvl(sum(t.qty), 0)
                            from tlm_packlist_item t
                           where t.orderid = o.orderid
                             and t.order_itemno = m.itemno
                             and trim(t.bn) = trim(b.bn))) availqty
  from mrqitembatch b
  join mrqitem m
    on m.orderid = b.orderid
   and m.itemno = b.itemno
  join orders o
    on o.orderid = m.req_orderid
  join orders o2
    on o2.orderid = b.orderid
  join pnrreg p
    on p.partid = b.partid
  left join snrreg s
    on s.partserid = b.partserid
  left join stock sk
    on trim(o.stock) = trim(sk.stock)
  join station st
    on trim(sk.station) = trim(st.station)
  join organisation org
    on trim(o.organisation) = trim(org.organisation)
 where (b.partserid is null or (b.partserid > 0 and b.seqno = 1))
   and o.orderid = '1021798')

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值