• <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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            表空間數(shù)據庫及存儲在該數(shù)據庫中的表之間的邏輯層。表空間在數(shù)據庫中創(chuàng)建,表在表空間中創(chuàng)建。

            使用表空間的一個明顯的好處是能夠把數(shù)據合理的分布存儲在不同的磁盤上或者存儲在磁盤的不同位置上,有助于提高數(shù)據存取的效率。

            DB2 的表空間按管理方式分為兩種:系統(tǒng)管理空間(System Management Space,SMS)和數(shù)據庫管理空間(Database Management Space,DMS)。

            按類型分為:規(guī)則表空間、大對象表空間、系統(tǒng)臨時表空間、用戶臨時表空間。

            規(guī)則表空間中包含用戶數(shù)據的表。默認用戶表空間名為USERSPACE1,索引也存儲在規(guī)則表空間中,另外系統(tǒng)目錄表也放在規(guī)則表空間中。默認的系統(tǒng)目錄表空間名為SYSCATSPACE。

            臨時表空間分為系統(tǒng)臨時表空間和用戶臨時表空間。

            系統(tǒng)臨時表空間用來存儲各種數(shù)據操作(排序、重組表、創(chuàng)建索引、連接表)中所需的內部臨時數(shù)據,雖然可以創(chuàng)建任意多個系統(tǒng)臨時表空間,但建議用戶只使用大多數(shù)表所使用的頁大小創(chuàng)建一個,默認系統(tǒng)臨時表空間名為TEMPSPACE1。

            用戶臨時表空間用來存儲已說明全局臨時表(已說明全局臨時表存儲的是應用程序臨時數(shù)據)。用戶臨時表空間不是在數(shù)據庫創(chuàng)建時默認創(chuàng)建的。

            SMS每個容器是操作系統(tǒng)的文件空間中的一個目錄;DMS每個容器是一個固定的、預分配的文件,或是物理設備。

            SMS的管理比較簡單,由操作系統(tǒng)自動管理,空間的大小隨數(shù)據量的變化系統(tǒng)自動調整。

            DMS是由數(shù)據庫管理的,空間大小在創(chuàng)建時確定,空間不夠時要手工添加或刪除部分數(shù)據以釋放空間。

            大多數(shù)情況下,DMS的性能比SMS好。

            用命令行方式創(chuàng)建SMS表空間的簡單語法:

            CREATE TABLESPACE ; MANAGED BY SYSTEM USING (' ;')

            例一:在Windows上創(chuàng)建一個SMS表空間:

            CREATE TABLESPACE RESOURCE MANAGED BY SYSTEM USING ('d:\acc_tbsp','e:\acc_tbsp','f:\acc_tbsp')

            完成的結果為在D、E、F三個磁盤上創(chuàng)建了三個名稱為acc_tbsp的文件夾,每個文件夾下面都有一個名為SQLTAG.NAM的文件。

            例二:刪除例一所創(chuàng)建的SMS表空間:

            DROP TABLESPACE RESOURCE

            運行完這條命令,相應的表空間會從DB2注冊表中刪除,但是磁盤上的三個文件夾仍然存在,需要手工刪除。

            用命令行方式創(chuàng)建DMS表空間的簡單語法:

            CREATE TABLESPACE ; MANAGED BY DATABASE USING (FILE ' ;'

            或者

            CREATE TABLESPACE ; MANAGED BY DATABASE USING (DEVICE ' ;'

            例三:在Windows上創(chuàng)建一個DMS表空間,使用各自有5000頁的兩個文件容器:

            CREATE TABLESPACE RESOURCE MANAGED BY DATABASE USING (FILE 'd:\db2data\acc_tbsp' 5000, FILE 'e:\db2data\acc_tbsp' 5000)

            運行結果為:在D、E磁盤的db2data文件夾下面各創(chuàng)建了一個名為acc_tbsp的文件,大小都為20000K(默認情況下每頁大小為4K)。

            例四:在例三所創(chuàng)建的表空間中添加一個容器:

            ALTER TABLESPACE RESOURCE ADD(FILE 'f:\db2data\acc_tbsp' 5000)

            運行的結果為在RESOURCE表空間中包含了三個容器(文件):d:\db2data\acc_tbsp、 e:\db2data\acc_tbsp、 f:\db2data\acc_tbsp。

            例五:用RESIZE子句更改例三所創(chuàng)建的表空間的容器的大小:

            ALTER TABLESPACE RESOURCE RESIZE (file 'd:\db2data\acc_tbsp' 8000, file 'e:\db2data\acc_tbsp' 8000, file 'f:\db2data\acc_tbsp' 8000)

            每個容器(文件)的大小變?yōu)?000頁。把容器的容量變大不會出錯,但是如果容器中的數(shù)據已經充滿,再把容器的容量縮小,則會引起錯誤。

            例六:用EXTEND子句更改例三所創(chuàng)建的表空間的容器的大小:

            ALTER TABLESPACE RESOURCE EXTEND (file 'd:\db2data\acc_tbsp' 1000, file 'e:\db2data\acc_tbsp' 1000, file 'f:\db2data\acc_tbsp' 1000)

            該命令的運行結果為在原有容量的基礎之上,每個容器再增加1000頁。

            例七:刪除例三中創(chuàng)建的DMS表空間:

            DROP TABLESPACE RESOURCE

            運行的結果為在DB2的注冊表中把RESOURCE表空間刪除,同時在磁盤上把相對應的文件夾和文件都一起自動刪除。

            例八:在UNIX上創(chuàng)建一個DMS表空間,使用各有10000頁的3個邏輯卷:

            CREATE TABLESPACE RESOURCE MANAGED BY DATABASE USING (DEVICE '/dev/rdblv6' 10000, DEVICE '/dev/rdblv7' 10000, DEVICE '/dev/rdblv8' 10000)

            上面語句中提到的UNIX設備必須已經存在,且實例擁有者和SYSADM組必須能夠寫入它們。

            SMS與DMS的對比
            特性                                        SMS         DMS
                        能夠在表空間中動態(tài)增加容器的數(shù)目嗎           N           Y
                        能夠把索引數(shù)據存放到不同表空間的表中嗎       N           Y
                        能夠把大對象數(shù)據存放到不同表空間的表中嗎     N           Y
                        表可以分散存放到多個表空間中嗎               N           Y
                        僅在需要時才分配空間嗎                       Y           N
                        表空間可以被放在不同的磁盤中嗎               Y           N
                        創(chuàng)建之后,區(qū)段大小能夠改變嗎                 N           N

            例九:創(chuàng)建系統(tǒng)臨時表空間:

            CREATE SYSTEM TEMPORARY TABLESPACE tmp_tbsp MANAGED BY SYSTEM USING(‘d:\tmp_tbsp’,’e:\tmp_tbsp’)

            系統(tǒng)臨時表只能存儲在系統(tǒng)臨時表空間中,所以數(shù)據庫必須始終至少有一個系統(tǒng)臨時表空間。

            例十:創(chuàng)建用戶臨時表空間:

            CREATE USER TEMPORARY TABLESPACE usr_tbsp MANAGED BY DATABASE USING(FILE ‘d:\db2data\user_tbsp’ 5000, FILE ‘e:\db2data\user_tbsp’ 5000)

            用戶臨時表空間用于存儲已說明的臨時表(用 DECLARE GLOBAL TEMPORARY TABLE 語句定義)

            例十一:用RENAME語句給表空間重命名:

            RENAME TABLESPACE RESOURCE TO RES1

            用該語句給表空間重命名之后,將自動更改所有引用該表空間的目錄記錄,所以無須關心該表空間中的個別對象。

            例十二:在RESOURCE表空間中創(chuàng)建一張名為T1的表:

            CREATE TABLE T1(ABC INT) IN RESOURCE

            精品国产乱码久久久久软件| 亚洲国产另类久久久精品| 久久国产视频99电影| 天天做夜夜做久久做狠狠| 久久久久亚洲AV无码专区首JN| 久久久久久九九99精品| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久WWW免费人成一看片| 成人久久综合网| 97久久国产露脸精品国产| 91性高湖久久久久| 久久久久亚洲AV无码麻豆| 四虎国产精品成人免费久久| 97久久精品无码一区二区天美| 色综合久久久久综合99| 青青青伊人色综合久久| 人妻精品久久久久中文字幕69 | 亚洲人成无码www久久久| 国产亚洲精品美女久久久| 国产毛片欧美毛片久久久| 久久夜色精品国产www| 久久伊人精品青青草原高清| 日本久久久久亚洲中字幕| 久久久久久久久久久精品尤物| 久久亚洲中文字幕精品一区| 狠狠色丁香婷婷综合久久来来去| 久久99精品久久久久子伦| 欧洲成人午夜精品无码区久久 | 久久99精品国产麻豆宅宅| 影音先锋女人AV鲁色资源网久久| 欧美精品福利视频一区二区三区久久久精品| 91精品国产91久久久久福利 | 欧美久久久久久午夜精品| 欧美综合天天夜夜久久| 99久久人妻无码精品系列| 久久精品国产亚洲av高清漫画| 国内精品综合久久久40p| 97香蕉久久夜色精品国产| 中文成人久久久久影院免费观看| 日本欧美国产精品第一页久久| 欧美日韩精品久久久免费观看|