DB2中表空间的管理

表空间是数据库及存储在该数据库中的表之间的逻辑层。表空间在数据库中创建,表在表空间中创建。

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

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

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

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

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

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

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

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

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

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

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

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

CREATE TABLESPACE MANAGED BY SYSTEM USING (‘ ‘)

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

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 MANAGED BY DATABASE USING (FILE ‘ ‘ )

或者

CREATE TABLESPACE MANAGED BY DATABASE USING (DEVICE ‘ ‘ )

例三:在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)。

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

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#p#

运行的结果为在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 SYST#p#EM 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
 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/275958.html<

(0)
运维的头像运维
上一篇2025-05-10 10:41
下一篇 2025-05-10 10:43

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注