• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • oracle中實現主鍵的自動增加

    發表于:2007-05-25來源:作者:點擊數: 標簽:oracle主鍵增加自動實現
    實現方法1: 建立一個最小為1,最大為nomaxvalue的一個序列號會自動循環的序列 create sequence 序列名 increment by 1 start with 1 nomaxvalue nocycle; 當向表中插入數據時,SQL語句寫法如下: SQL insert into 表名 values(序列名.nextval,列1值,列2值, .

    實現方法1:
    建立一個最小為1,最大為nomaxvalue的一個序列號會自動循環的序列

    create sequence 序列名
    increment by 1
    start with 1
    nomaxvalue 
    nocycle;

    當向表中插入數據時,SQL語句寫法如下:
    SQL> insert into 表名 values(序列名.nextval,列1值,列2值, ...);
    當要重用該序列號時,有兩種方法:
    a. 在同一個sql塊中重用:
    SQL>insert into表名(序列名.currval, 列1值,列2值...);
    b. 在存儲進程中,將該值取到一個參數中:
    SQL>select序列名.nextval into 參數名 from dual;
    然后在重用該序列號的地方調用這個參數。

    實現方法2:(利用觸發器)

    SQL> create sequence a_sequence
      2  start with 1
      3  increment by 1;

    序列已創建。

    SQL> create table t (n number ,v varchar2(10));

    表已創建。

    SQL> create or replace trigger t_trg
      2  before insert or update on t
      3  for each row
      4  begin
      5    select a_sequence.nextval into :new.n from dual;
      6  end;
      7  /

    觸發器已創建

    SQL> insert into t values(111,'ok');

    已創建 1 行。

    SQL> select *  from t;

             N V
    ---------- ----------
             1 ok


    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>