DB2表空间管理

转载 2007年09月29日 11:49:00
表空间是数据库及存储在该数据库中的表之间的逻辑层。表空间在数据库中创建,表在表空间中创建。

  使用表空间的一个明显的好处是能够把数据合理的分布存储在不同的磁盘上或者存储在磁盘的不同位置上,有助于提高数据存取的效率。

  DB2 的表空间按管理方式分为两种:系统管理空间(System Management Space,SMS)和数据库管理空间(Database Management Space,DMS)。

  按类型分为:规则表空间、大对象表空间、系统临时表空间、用户临时表空间。

  规则表空间中包含用户数据的表。默认用户表空间名为USERSPACE1,索引也存储在规则表空间中,另外系统目录表也放在规则表空间中。默认的系统目录表空间名为SYSCATSPACE。

  临时表空间分为系统临时表空间和用户临时表空间。

  系统临时表空间用来存储各种数据操作(排序、重组表、创建索引、连接表)中所需的内部临时数据,虽然可以创建任意多个系统临时表空间,但建议用户只使用大多数表所使用的页大小创建一个,默认系统临时表空间名为TEMPSPACE1。

  用户临时表空间用来存储已说明全局临时表(已说明全局临时表存储的是应用程序临时数据)。用户临时表空间不是在数据库创建时默认创建的。

  SMS每个容器是操作系统的文件空间中的一个目录;DMS每个容器是一个固定的、预分配的文件,或是物理设备。

  SMS的管理比较简单,由操作系统自动管理,空间的大小随数据量的变化系统自动调整。

  DMS是由数据库管理的,空间大小在创建时确定,空间不够时要手工添加或删除部分数据以释放空间。

  大多数情况下,DMS的性能比SMS好。


  用命令行方式创建SMS表空间的简单语法:

  CREATE TABLESPACE <NAME> MANAGED BY SYSTEM USING ('<path>')


  ★例一:在Windows上创建一个SMS表空间:

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

  完成的结果为在D、E、F三个磁盘上创建了三个名称为acc_tbsp的文件夹,每个文件夹下面都有一个名为SQLTAG.NAM的文件。


  ★例二:删除例一所创建的SMS表空间。

  DROP TABLESPACE RESOURCE

  运行完这条命令,相应的表空间会从DB2注册表中删除,但是磁盘上的三个文件夹仍然存在,需要手工删除。


  用命令行方式创建DMS表空间的简单语法:

  CREATE TABLESPACE <NAME> MANAGED BY DATABASE USING (FILE '<path>' <size>)

  或者

  CREATE TABLESPACE <NAME> MANAGED BY DATABASE USING (DEVICE '<path>' <size>)


  ★例三:在Windows上创建一个DMS表空间,使用各自有5000页的两个文件容器:

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

  运行结果为:在D、E磁盘的db2data文件夹下面各创建了一个名为acc_tbsp的文件,大小都为20000K(默认情况下每页大小为4K)。


  ★例四:在例三所创建的表空间中添加一个容器。

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

  运行的结果为在RESOURCE表空间中包含了三个容器(文件):d:/db2data/acc_tbsp、 e:/db2data/acc_tbsp、 f:/db2data/acc_tbsp。


  ★例五:用RESIZE子句更改例三所创建的表空间的容器的大小。

  ALTER TABLESPACE RESOURCE RESIZE (FILE 'd:/db2data/acc_tbsp' 8000, FILE 'e:/db2data/acc_tbsp' 8000, FILE 'f:/db2data/acc_tbsp' 8000)

  每个容器(文件)的大小变为8000页。把容器的容量变大不会出错,但是如果容器中的数据已经充满,再把容器的容量缩小,则会引起错误。


  ★例六:用EXTEND子句更改例三所创建的表空间的容器的大小。

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

  该命令的运行结果为在原有容量的基础之上,每个容器再增加1000页。


  ★例七:删除例三中创建的DMS表空间。

  DROP TABLESPACE RESOURCE

  运行的结果为在DB2的注册表中把RESOURCE表空间删除,同时在磁盘上把相对应的文件夹和文件都一起自动删除。


  ★例八:在UNIX上创建一个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

  能够在表空间中动态增加容器的数目吗                N         Y

  能够把索引数据存放到不同表空间的表中吗            N         Y

  能够把大对象数据存放到不同表空间的表中吗          N         Y

  表可以分散存放到多个表空间中吗                    N         Y

  仅在需要时才分配空间吗                            Y         N

  表空间可以被放在不同的磁盘中吗                    Y         N

  创建之后,区段大小能够改变吗                      N         N


  ★例九:创建系统临时表空间。

  CREATE SYSTEM TEMPORARY TABLESPACE tmp_tbsp MANAGED BY SYSTEM USING('d:/tmp_tbsp','e:/tmp_tbsp')

  系统临时表只能存储在系统临时表空间中,所以数据库必须始终至少有一个系统临时表空间。


  ★例十:创建用户临时表空间。

  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表空间中创建一张名为T1的表

  CREATE TABLE T1(ABC  INT) IN RESOURCE

原文(http://publish.it168.com/2006/0215/20060215096201.shtml?positioncode=1543)

DB2 自动存储表空间(Automatic Storage)增加和删除存储路径

本文举例说明修改DB2自动存储表空间storage group的办法,如果您对storage group还不了解,请先参考链接。 原本storage group有path1和path2,目标增加...
  • qingsong3333
  • qingsong3333
  • 2017年03月09日 21:53
  • 1155

DB2支持的三种表空间SMS、DMS、DMS的自动存储

文章来源:http://blog.itpub.net/25744374/viewspace-750054/ DB2中,表空间是数据库与这个数据库中存储的表之间的逻辑层。表空间在数据库...
  • aosica321
  • aosica321
  • 2015年02月03日 22:19
  • 976

db2 系统临时表空间

确保系统临时表空间的页大小符合要求 更大记录标识符(RID)的使用增加了来自查询或定位更新的结果集的行大小。如果结果集中的行大小接近于现有系统临时表空间的最大行长度限制,那么可能需要创建具有更大...
  • pianzif
  • pianzif
  • 2014年05月26日 14:28
  • 1788

DB2 只进行单个表空间的恢复

问题:我有一个DB2的备份要拿到新环境来恢复,但由于某些原因,比如磁盘空间不足,只想恢复其中的一个表空间,如何做? 方法:可以使用表空间级别的恢复,测试过程如下 1.) 查看当前数据库的状态,...
  • qingsong3333
  • qingsong3333
  • 2016年05月04日 14:42
  • 1671

DB2表空间操作详解

1.LARGE, REGULAR, SYSTEM TEMPORARY, or USER TEMPORARY 指定要创建的表空间的类型,如果不指定,默认类型是由”MANAGED BY”字句决定的。 LA...
  • lzghxjt
  • lzghxjt
  • 2015年10月26日 00:26
  • 1853

DB2表空间的静默状态

DB2表空间是DB2数据库的重要组成部分,下面就为您详细介绍DB2表空间的静默状态,供您参考,希望对您能够有所帮助  。   DB2表空间的静默状态:   对于DB2数据库,可利用...
  • pianzif
  • pianzif
  • 2014年04月19日 02:20
  • 1306

db2 查看表空间使用率

1. 统计所有节点表空间使用率   select substr(TABLESPACE_NAME,1,20) as TBSPC_NAME,bigint(TOTAL_PAGES * PAGE_SIZE)...
  • u011677176
  • u011677176
  • 2015年02月11日 11:30
  • 1955

db2中获取某个表/索引占用空间的大小

db2中获取某个表/索引占用空间的大小    在数据库运维中,经常会遇到需要统计db2表大小的问题。在db2中提供了3种方法已供我们选择。分别为db2pd -tcbstats、admin_get_ta...
  • t0nsha
  • t0nsha
  • 2016年01月24日 12:34
  • 4652

DB2 查看表空间使用率

1. 统计所有节点表空间使用率   select substr(TABLESPACE_NAME,1,20) as TBSPC_NAME,bigint(TOTAL_PAGES * PAGE_SIZE)...
  • xiadingling
  • xiadingling
  • 2016年02月04日 14:02
  • 559

存在多个系统临时表空间时,DB2如何选择?

DB2中如果有多个系统临时表空间,那么到底会用到哪一个呢?
  • qingsong3333
  • qingsong3333
  • 2017年06月24日 21:26
  • 1477
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:DB2表空间管理
举报原因:
原因补充:

(最多只允许输入30个字)