如何在Oracle下建立自動遞增欄位

來源:互聯網
上載者:User

原文發表於網易部落格 2010-09-17 17:30:17

     先前在學校時候是有看過並且也用過一段時間的Mysql的.在Mysql中建立一個自動遞增的欄位,比較簡單.
比如建表語句中,id int key auto_increment,最後在insert時,對應欄位填空就行了.
     但在oracle中,還沒有見到周圍人有直接建立一個自增欄位的.上網找了下,不少資料中都說不支援.要實現自增欄位,只能通過其他方式來實現.比如,sequence.
     create sequence seq_test minvalue 1 maxvalue 99999 start with 1 increment by 1 cycle nocache;

    其中 cycle表示達到了最大值之後又從最小值開始迴圈.nocache是不把sequence的值緩衝起來.
    這樣,insert一條記錄時,在對應位置填寫sequence.nextval即可,也可以使用sequence.currval來查看當前的sequence的值.

    不同的是,如果沒有調用過sequence.nextval,則調用sequnce.currval會報錯.調用sequence.nextval使得sequence的值遞增,然後返回當前值.sequence.currval則不改變sequence的值.

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.