oracle利用觸發器實現自增列,oracle利用觸發器

來源:互聯網
上載者:User

oracle利用觸發器實現自增列,oracle利用觸發器

oracle利用觸發器實現自增列

 

oracle沒有自增列功能,mysql 和 sqlserver 分別用auto_increment和identity(1,1)來實現自增。oracle要實現只能通過序列實現,每次插入的時候通過取序列的值顯示的給自增列,感覺有些不方便,這裡使用觸發器來代替,從而使插入的時候三者資料庫在文法上一致,便於DAO代碼的移植。下面是ORACLE實現樣本,步驟如下:
                                                                                                                                      

1、建立表

create tabletest_user(

  user_id   number(10,0) primary key,

  user_name varchar2(40)

);

 

2、建立序列

create sequencetest_user_seq start with 1 maxvalue 9999999999 increment by 1;  

 

3、建立觸發器

create or replace

triggertest_user_trigger      

before insert ontest_user      

for each row      

begin      

selecttest_user_seq.nextval into :new.user_id from dual;     

end ;  

4、插入資料

insert intotest_user(user_name) values('tom');

insert intotest_user(user_name) values('jack');

 

5、測試結果

 

select * from test_user;

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.