• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Oracle、DB2、PostgreSQL之Sequence總結

            Posted on 2010-05-15 22:46 Prayer 閱讀(371) 評論(0)  編輯 收藏 引用 所屬分類: DB2
            Sequence是數據庫系統按照一定規則自動增加的數字序列。這個序列一般作為代理主鍵(因為不會重復),沒有其他任何意義。

            Sequence是數據庫系統的特性,有的數據庫有Sequence,有的沒有。比如Oracle、DB2、PostgreSQL數據庫有Sequence,MySQL、SQL Server、Sybase等數據庫沒有Sequence。

            根據我個人理解,Sequence是數據中一個特殊存放等差數列的表,該表受數據庫系統控制,任何時候數據庫系統都可以根據當前記錄數大小加上步長來獲取到該表下一條記錄應該是多少,這個表沒有實際意義,常常用來做主鍵用,非常不錯,呵呵,不過很郁悶的各個數據庫廠商尿不到一個壺里--各有各的一套對Sequence的定義和操作。在此我對常見三種數據庫的Sequence的定義和操作做一個對比和總結,以便日后查看。

            一、定義Sequence

            定義一個seq_test,最小值為10000,最大值為99999999999999999,從20000開始,增量的步長為1,緩存為20的循環排序Sequence。

            Oracle的定義方法:
            create sequence seq_test
            minvalue 10000
            maxvalue 99999999999999999
            start with 20000
            increment by 1
            cache 20
            cycle
            order;

            DB2的寫法:
            create sequence seq_test
            as bigint
            start with 20000
            increment by 1
            minvalue 10000
            maxvalue 99999999999999999
            cycle
            cache 20
            order;

            PostgreSQL的寫法:
            create sequence seq_test
            increment by 1
            minvalue 10000
            maxvalue 99999999999999999
            start 20000
            cache 20
            cycle;

            二、Oracle、DB2、PostgreSQL數據庫Sequence值的引用參數為:currval、nextval,分別表示當前值和下一個值。下面分別從三個數據庫的Sequence中獲取nextval的值。

            Oracle中:seq_test.nextval
            例如:select seq_test.nextval from dual;

            DB2中:nextval for SEQ_TOPICMS
            例如:values nextval for seq_test;

            PostgreSQL中:nextval(seq_test)
            例如:select nextval(seq_test);

            三、Sequence與indentity的區別與聯系

            Sequence與indentity的基本作用都差不多。都可以生成自增數字序列。
            Sequence是數據庫系統中的一個對象,可以在整個數據庫中使用,和表沒有任何關系;indentity僅僅是指定在表中某一列上,作用范圍就是這個表。

            久久久噜噜噜久久中文字幕色伊伊| 色综合久久久久综合体桃花网| 韩国三级中文字幕hd久久精品 | 99久久免费国产精精品| 狠狠综合久久综合中文88 | 国产精品美女久久久久久2018| 99久久精品免费看国产| 久久精品国产色蜜蜜麻豆| 7国产欧美日韩综合天堂中文久久久久 | 久久久久亚洲AV无码网站| 99久久精品免费| 久久w5ww成w人免费| 99久久免费国产精品特黄| 久久精品亚洲欧美日韩久久| 999久久久免费精品国产| 一本久久知道综合久久| 国产精品久久久久蜜芽| 久久久久久A亚洲欧洲AV冫| 久久777国产线看观看精品| 久久亚洲精精品中文字幕| 久久婷婷色香五月综合激情| 久久国产三级无码一区二区| 99久久国产热无码精品免费久久久久| 日韩久久久久久中文人妻| 99精品国产99久久久久久97| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久午夜无码鲁丝片午夜精品| 国产一久久香蕉国产线看观看| 欧美午夜精品久久久久免费视| 久久婷婷国产剧情内射白浆| 欧美日韩精品久久久免费观看| 久久综合精品国产一区二区三区| 久久久WWW免费人成精品| 久久精品无码免费不卡| 99久久国产主播综合精品| 国产精品成人久久久久三级午夜电影 | 欧美激情精品久久久久久| 久久久久国色AV免费看图片| 久久99精品国产麻豆蜜芽| 看全色黄大色大片免费久久久| 精品国产乱码久久久久软件|