




已阅读5页,还剩72页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
db2 安装配置以及相关技术手册安装配置以及相关技术手册 topsofttopsoft 二零零六年八月二零零六年八月 目目 录录 目目 录录2 1准备准备.5 2安装需求安装需求.6 3详细安装步骤详细安装步骤.7 4db2 的配置与建库的配置与建库.29 5db2 数据库缓冲池设置数据库缓冲池设置.38 6db2 数据库表空间建立数据库表空间建立.41 7oracle 到到 db2 数据库迁移技术问题数据库迁移技术问题 .52 7.1oracle 迁移到 db2 后,如何对 db2 服务器进行配置和管理?.52 7.1.1db2 udb 体系结构图.53 7.1.2db2 udb 内存结构.53 7.1.3db2 udb 数据库结构.53 7.1.4db2 udb 数据库的逻辑机构54 i.db2 的数据库对象.54 ii.系统55 iii.实例.56 iv.数据库.56 v.表空间57 vi.表 58 vii.视图.58 viii.索引58 ix.触发器 59 7.2db2 数据库的相关概念.59 i.分区数据库 .59 ii.节点59 iii.日志.60 iv.权限.60 v.特权60 vi.配置参数 61 vii.系统目录.61 viii.约束62 ix.数据完整性 62 x.主键63 xi.外键 63 xii.父表.63 xiii.隔离级别63 xiv.工作单元64 xv.连接 .65 xvi.数据安全性65 xvii.恢复65 xviii.数据元素.65 8oracle 中的数据类型与中的数据类型与 db2 数据类型的对应关系是什么?数据类型的对应关系是什么? .66 9oracle 中的一些常用函数如中的一些常用函数如 decode()() 、爬树查询等在、爬树查询等在 db2 中是如何实现的,若没中是如何实现的,若没 有相关实现,解决方案是什么?有相关实现,解决方案是什么?68 9.1db2 中对 oracle 系统函数 decode()的实现68 9.2db2 中对 oracle 系统中的爬树查询的对应实现 68 10oracle 中的中的 squence 和和 dual,对应到,对应到 db2 中如何实现中如何实现68 10.1squence 在 db2 中的实现.68 10.2oracle 系统表 dual 在 db2 中相对应的系统表是 sysibm.sysdummy1 69 11oracle 到到 db2 数据迁数据迁移移问题问题 .72 11.1准备工作72 11.2数据迁移步骤:72 topsoft topsoft 1 准备准备 取得 db2 enterprise edition v8.2 for windows 安装光盘。 topsoft 2 安装需求安装需求 磁盘:至少 1g 的 fat32 或 ntfs 格式磁盘空间。推荐 3g 的 ntfs 格式磁盘空间。 内存和 cpu:至少 256mb 内存,推荐 2gmb 内存。对于 32 位 db2 产品,需要有奔腾或与奔 腾兼容的 cpu。对于 64 位 db2 产品,需要 itanium 或与 itanium 兼容的 cpu。 操作系统:windows 2000/xp/2003,推荐使用 windows 的各种 server/advance server/data center 版 本。 topsoft 3 详细安装步骤详细安装步骤 运行 db2 光盘,打开并运行 setup.exe 开始安装,如下图 如上图,单击【安装产品】 topsoft 如上图,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,选择“我接受许可证协议中的全部条款(a) ”后,单击【下一步】 topsoft 如上图,选择“定制安装” , 单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,默认目录为 c: program filesibmsqllib,为了获得更好的性能,改为非操作系统所在的分 区上安装 db2,并且不在 program files 文件夹内安装,目的是避免目录中的空格引起不必要的麻烦。 单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,如果计算机在域内,则需要输入域用户的用户名和密码;如果计算机不在域内,则输入登陆 计算机的用户名和密码。并且,这里所输入的用户名和密码应该隶属于 administators 组,密码要保证 正确,在此仅对两次输入密码匹配性进行一致性校验,而不对密码的有效性经进行校验。为了 db2 服 务器管理的方便,请取消选择“对其余 db2 服务使用同一个用户名和密码” ,单击【下一步】 topsoft 如上图,因为上面输入的密码是正确有效的,所以选择【否】 topsoft 如上图,单击【下一步】 如上图,单击【确定】 如上图,选择“创建 db2 实例” ,单击【下一步】 topsoft 如上图,选择“db2” ,单击【下一步】 topsoft 如上图,在此推荐使用新建用户,用户名 topicis,并且选中“对其余 db2 服务使用同一个用户名和密 码(u) ” ,单击【下一步】 topsoft 如上图,选择“准备 db2 工具目录和仓库控制数据库” ,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,选择“将任务延迟到完成安装后进行” ,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,推荐将设置信息复制并保存起来,以供查看。单击【安装】 topsoft 如上图,单击【完成】 ,完成 db2 服务器的安装。db2 接着会开始启动服务,请看下节的 db2 的配置。 topsoft 4 db2 的配置与建库的配置与建库 注意: db2 在创建数据库时候,会自动创建一个模式。 “模式名”会默认为“当前用户名” 。由于该系 统在设计时采用 topicis 模式,所以登陆系统创建数据库的用户,名称必需为“topicis” 。 (即:在本机 新建一个 topicis 用户,并用该用户登录来创建数据库) 。 以下仅为一创建 db2 数据库例子,数据库名字可以有用户自己决定。 (例子仅供参考) 在安装 db2 的最后一步,如上图单击【完成】后,会启动 db2 的服务,进入 db2 的启动板 如上图,单击【创建样本数据库】 topsoft 如上图,选择【db2 udb 样本】 如上图,完成后,单击【确定】 ,完成样本数据库的创建。 接下来,创建应用数据库。 打开 db2 控制中心, 打开方法“开始/所有程序/ibm db2/一般管理工具/控制中心” ,也可以直接在系 统托盘中右键点击 db2,选择“控制中心”来打开。 topsoft 如上图,在控制中心视图上选择“高级” ,单击【确定】 ,并展开控制中心的目录树中的样本数据库 sample topsoft 如上图,在“数据库”的节点上单击鼠标右键, topsoft 如山图,选择【标准】 创建一个数据库 topicis,别名和注释也为 topicis,单击【下一步】 topsoft 如上图,选择“低维护自动增加(系统管理空间) (l) ” ,并单击【添加】指定一个容器来存储用户 表。容器可以是一个文件目录,可以在 windows 中随意创建。单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,单击【下一步】 如上图,单击【下一步】 topsoft 如上图,单击【下一步】 topsoft 如上图,单击【显示命令】 ,可以显示创建命令 单击【完成】 选择【否】 ,完成 topicis 数据库的创建。 5 db2 数据库缓冲池设置数据库缓冲池设置 db2 数据库建好后,在该数据库上创建缓冲池如下图: topsoft 点击创建: topsoft 系统默认“页大小”下拉单中有 4、8、16、32 四个选项,为了便于操作,对应的“缓冲池名”我们分 别定为 4k、8k、16k、32k(这四个缓冲池都必须建) 。另外在红色框内也可根据需要,自己定义页设 计的大小。除此四个之外我们还需要建立一个“缓冲池名”为 user32k 的缓冲池。如下图 topsoft 建议该页计的大小为 3500k。 (用户可根据具体需要修改).点击确定完成缓冲池的创建。 6 db2 数据库表空间建立数据库表空间建立 db2 数据库建好后,在该数据库上创建表空间如下图: topsoft 点击创建: topsoft 点击【下一步】: topsoft 我们根据项目的需要,要建立四个常规、一个大型(用来存放如图片等大字段)和一个用户临时类型的 表空间(建议表空间命名规则和建立的缓冲池对应:例如 user4k 对应的缓冲池为 4k、user8k 对应 的缓冲池为 8k、user16k 对应的缓冲池为 16k、user32k 对应的缓冲池为 32k,大型表空间对应 32k 缓冲池,用户临时表空间对应 4k 缓冲池) 。这里仅以 user4k 为例加以说明。点击【下一步】:进入 下图 topsoft 在该窗口中用户建立的“缓冲池”将显示在缓冲池列表中,选择合适的缓冲池点击【下一步】:如下 图 topsoft 点击【下一步】:如图 topsoft 该窗口要为建立的表空间指定容器,单击【添加】 topsoft 红色标记部分可以调整容器的大小。 (建议使用 200,也可根据需要用户自己决定)点确定进入下图: topsoft 点【下一步】: topsoft 点【下一步】 topsoft 点【下一步】: topsoft 点“完成”完成 user4k 表空间的建立,其他表空间的操作类似,这里不再做具体说明。 7 oracle 到到 db2 数据库迁移技术问题数据库迁移技术问题 oracle 迁移到 db2 后,如何对 db2 服务器进行配置和管理? oracle 中的数据类型与 db2 数据类型的对应关系是什么? oracle 中的一些常用函数如 decode() 、爬树查询等在 db2 中是如何实现的,若没有相关实现, 解决方案是什么? oracle 中的 squence 和 dual,对应到 db2 中如何实现 7.1oracle 迁移到迁移到 db2 后,如何对后,如何对 db2 服务器进行配置和管理?服务器进行配置和管理? 理解 oracle 与 db2 数据库系统的体系结构和相关概念是进行配置管理的依据,也是快速掌握数 据库系统的捷径。有关 oracle 这方面的资料文档网上很多,在此不做介绍。下面简要介绍一下 db2 体 系结构和相关概念。 topsoft 7.1.1db2 udb 体系结构图体系结构图 7.1.2db2 udb 内存结构内存结构 包缓存 为存储静态和动态 sql 语句而分配的内存。 缓冲池 在将数据刷新到磁盘之前,为存储数据而分配的内存。 日志缓冲区 在将所有对数据库的更改刷新到磁盘上的日志之前,用来存储这些更改的内存。 7.1.3db2 udb 数据库结构数据库结构 如上图,说明: topsoft 驱动器/目录 在 create database 命令中指定的驱动器或目录。 db2 实例名称 db2 实例所有者的名称。 node0000 数据库的分区数。0 表示非分区的数据库。 sql00001 从 1 开始的数据库 id。 sqlogdir 数据库的默认日志目录。 sqlt0000.0 目录表空间 syscatspace。 sqlt0001.0 临时表空间 tempspace1。 sqlt0002.0 用户表空间 userspace1。 7.1.4db2 udb 数据库的逻辑机构数据库的逻辑机构 在 db2 数据库中,表、视图、存储过程、触发器等具体存储数据或对数据进行操作的实体都称为数据 库对象。db2 的逻辑机构包括系统、实例、数据库、表空间以及表、视图、过程、函数、触发器等对 象,下面做详细介绍: i.db2 的数据库对象的数据库对象 在 db2 数据库中,表、视图、存储过程、触发器等具体存储数据或对数据进行操作的实体 都称为数据库对象。如下图: topsoft ii. 系统系统 db2 是按照数据库对象的层次结构来组织的。层次结构中最顶层的对象就是系统。系统 表示安装 db2。控制中心维护它了解的系统的列表,并记录与每个系统进行通信所需要的信 息(例如,它的网络地址、操作系统和通信协议) 。 系统可以具有一个或多个 db2 实例,每个实例可以管理一个或多个数据库。数据库可 以是分区数据库,并使它们表空间驻留在数据库分区组上。表空间也可以存储表数据。 您可以: 将系统添加至控制中心。 与系统连接。 从控制中心中除去系统。 topsoft 实践表明:db2 中的系统名是与创建系统的用户名一一对应的。 iii.实例实例 实例是一种逻辑数据库管理器环境,在该环境中可以编目数据库和设置配置参数。可以 在同一物理服务器上创建多个实例,并为每个实例提供唯一的数据库服务器环境。多个实例 可以提供下列内容: 将一个实例用于开发环境,而将另一个实例用于生产环境。 为特定环境调整实例。 限制存取机密信息。 控制为每个实例指定 sysadm、sysctrl 和 sysmaint 权限。 优化每个实例的数据库管理器配置。 限制实例故障的影响。如果发生实例故障,则只有一个实例受影响。其它实例可以继续 正常工作。 多个实例将需要: 每个实例的附加系统资源(虚拟内存和磁盘空间) 。 更多管理任务,因为要管理附加实例。 在 windows 系统上,确保没有实例名与服务名称相同。 您可以: 创建实例。 删除实例。 启动实例。 停止实例。 连接实例。 iv.数据库数据库 关系数据库以表的集合来表示数据。表由定义的一组列和任何数目的行组成。每个表中 的数据在逻辑上是相关的,并且可以定义表之间的关系。可以根据数学原理和称为关系的操 作(例如 insert、select 和 update)来对数据进行查看和操作。 数据库是自描述的,因为它除了包含数据之外,还包含对它自身结构的描述。它包括一 组系统目录表,这些目录表描述数据的逻辑和物理结构;配置文件,它包含与数据库相关联 的参数值;恢复日志,它记录正在执行的事务以及可以归档的事务。 数据库可以是本地的或远程的。本地数据库在物理上位于正在使用的工作站中,而另一 机器上的数据库则认为是远程的。 您可以: 创建数据库。 将数据库添加至控制中心。 从控制中心中删除数据库。 备份数据库。 复原数据库。 配置数据库。 编目数据库。 取消编目数据库。 topsoft 连接至数据库。 使用 事件监视器监视表空间。 使用分区数据库。 使用联合系统。 对于 z/os 和 os/390 系统,在 db2 安装过程中预定义了缺省数据库 dsndb04。此数 据库具有缺省缓冲池(bp0)和缺省 db2 存储组(sysdeflt) 。 数据库名称 数据库名称是创建数据库时用户提供的标识名称。这些名称在对它们进行编目的位置中 必须是唯一的。该名称使数据库与本地数据库目录或系统数据库目录中的其它任何数据库区 别开来。 如果想要在通信环境中使用数据库,为了避免潜在的问题,则不要在数据库名称中使用 特殊字符 、# 和 $。另外,由于并不是所有键盘都有这些字符,所以,如果打算在另一地 域使用数据库,则不要使用这些字符。 可以为本地和远程数据库名称指定别名。 v. 表空间表空间 在数据库中的物理空间被组织成表空间集合。每个表空间由容器集合组成,每个容器是 对物理存储器(例如,机器上的目录、物理文件或设备(例如,硬盘驱动器) )的分配。在分 区环境中,表空间驻留在数据库分区组中。 将每个表分配给表空间。表可以将它的索引保存在第二个表空间中,将它的大对象保存在第 三个表空间中。可以将多个表分配给同一个表空间。系统试图将数据分布到它的表空间的容 器中。 将表分配给表空间并将表空间映射至物理存储器,可以使您对数据库性能具有一定控制 权。例如,可以将最快的存储设备用于最常用的表,将不常用的数据存储在较慢的设备上。 有两种类型的表空间: “系统管理空间” (sms) ,在该表空间中,操作系统的文件系统管理器分配和管理用来 存储表的空间。用户决定文件的位置、db2 控制它们的名称,而文件系统则负责管理它 们。缺省情况下,表是作为 sms 表空间来创建的。 “数据库管理空间” (dms) ,在该表空间中,数据库管理器控制存储空间。存储模型由 有限数目的设备(其空间由 db2 来管理)组成。管理员决定要使用的设备,而 db2 负 责管理那些设备上的空间。 您可以: 创建表空间。 删除表空间。 改变表空间的特征。 备份表空间。 恢复表空间。 前滚表空间。 授予和撤销对表空间的特权。 显示与表空间相关的对象。 使用事件监视器监视表空间。 topsoft vi.表表 关系数据库以表的集合来表示数据。表由在列和行中按逻辑排列的数据(通常称为记录) 组成。 每个表都有一个名称,而在表中每一列都有一个名称。表的各行之间没有任何特定的排 序,但是,可以按照由各行的列中的值所确定的顺序来检索行。表中的数据在逻辑上是相关 的。将所有数据库和表数据都分配给表空间。 您可以: 创建表。 通过插入、装入和导入数据来填充表。 定义表之间的关系。 控制对表的存取权。 删除表。 创建表的索引。 vii.视图视图 视图是查询一个或多个表所获得的结果。视图看起来象真正的表,但是实际上它只是对 一个或多个表中的数据的表示。 视图是一个逻辑表或虚拟表,它在物理存储器中并不存在。它是表示不需要维护的数据 的有效方法。当视图中显示的数据发生更改时,那些更改是对表本身的数据的更改结果。 视图可用来查看同一数据的不同表示法。视图是控制对机密数据的存取权的一种方法。根 据用户的需要,不同的用户可以对不同的列和行具有存取权。 您可以: 创建存取一个或多个数据源的视图。 创建一个视图来对一列中的所有值求和、选择最大值或者计算平均值。 创建存取视图而不是实际的表的应用程序。 删除视图。 viii.索引索引 可以在表上创建索引,它是对数据存取的一种帮助。它是指向表中的行的有序指针集。 每个索引都是根据表中一列或多列的数据值来建立的。索引是从表中的数据独立出来的 对象。当创建索引时,数据库管理器将构建结构,并且自动维护它。索引可以用于下列目的: 提供一种快速方法来根据表中各行在键列中的值来查找这些行。在某些情况下,可以在 索引中找到查询所需要的所有信息,从而不需要阅读整个实际表。 通过将一列或一组列定义为唯一索引或主键来强制执行唯一性规则。 提供了根据键列值来将表中的各行进行逻辑排序。 根据定义的索引顺序来在物理存储器中建立表中的行的群集。 您可以: 创建索引以提高性能。 创建唯一索引以强制执行唯一性规则。 删除索引。 topsoft 显示索引与其它对象之间的关系。 ix.触发器触发器 触发器定义一组操作,当在指定的表上执行更新、插入或删除时就会执行或触发这些操 作。可以创建触发器,以便使它们在指定的事件之前执行(前触发器)或者在指定的事件之 后执行(后触发器) 。触发器可以用于: 验证数据。确保新的数据值在可接受的范围内。这类似于检查约束。 数据完整性。确保通过更新相关表中相关联的数据记录来维护交叉表从属项。 通知。通过生成电子邮件通知来对管理员报警:存在潜在的表问题。 触发器存储在数据库中。这样更便于进行应用程序开发,因为不需要在每个应用程序中 编写触发器执行的操作。维护应用程序和数据库也更加容易,因为如果表的规则发生了 更改,则只需要修改相应的触发器,而不需要修改每个应用程序。 您可以: 创建触发器。 删除触发器。 7.2db2 数据库的相关概念数据库的相关概念 i.分区数据库分区数据库 分区关系数据库是由两个或多个数据库分区组成的数据库。在此类型的数据库中,数据 以散列形式存储。数据库分区由它自己的数据、索引、配置文件和事务日志组成。数据库分 区有时称为节点或数据库节点。 表可以位于一个或多个数据库分区中。当表的数据分布在多分区中时,它的一些行存储 在一个分区中,而其它行存储在其它分区中。数据检索和更新请求将自动分解为子请求,并 在适当的数据库分区中并行执行。用户应该很清楚数据库已划分为数据库分区。 通常情况下,由计算机组成的每个物理组件上都存在单个数据库分区。每个系统上的处 理器都由每个数据库分区的数据库管理器用来管理其数据(这些数据是数据库中总数据的一 部分) 。因为数据是跨数据库分区划分的,所以可以使用多台计算机上的多个处理器的能力来 满足信息请求。 数据检索和更新请求将自动分解为子请求,并在适当的数据库分区中并行执行。 用户交互作用是通过一个数据库分区来实现的,该数据库分区称为该用户的协调程序分 区。协调程序与应用程序在同一数据库分区上运行,但是,在远程应用程序的情况下,协调 程序将在与远程应用程序连接的数据库分区上运行。任何数据库分区都可以用作协调程序分 区。 ii. 节点节点 数据库分区有时称为节点或数据库节点。单一分区数据库就是只有一个数据库分区的数 据库。数据库中的所有数据都存储在该分区中。分区数据库就是具有两个或多个数据库分区 的数据库。表可以位于一个或多个数据库分区中。当表位于多分区上时,它的一些行存储在 一个分区中,而其它行存储在其它分区中。发出 sql 语句的用户应该很清楚数据库可能已 topsoft 划分为数据库分区。 iii.日志日志 日志与所有 db2 数据库相关联。日志保存对数据库对象和数据所作的所有更改的记录。 所有更改都是首先写入到内存中的日志缓冲区,然后在落实更改或者缓冲区已满时,就会移 动或刷新磁盘上的日志文件。在发生意外的情况下(例如,电源故障) ,将使用日志文件来使 数据库返回到一致状态(恢复) 。 有两种类型的日志记录: 循环日志记录,它使用圆形或环形日志文件来记录对数据库的更改。当填充了最后一个 日志时,就会重新循环使用第一个文件。由于可能会覆盖事务信息,因此,对这种类型 的日志记录不能进行前滚恢复。缺省情况下,创建数据库时将创建循环日志记录。 归档日志记录,它不会覆盖日志文件。它会创建附加日志来记录自从上次备份以来的所 有事务。这种类型的日志记录支持前滚恢复。 活动日志包含尚未落实或回滚的事务信息,或者那些尚未写入数据库文件但已落实的更 改。当正常处理不再需要活动日志中的所有更改时,日志就会关闭并且成为归档日志。循环 日志记录和归档日志记录都使用活动日志,而只有归档日志记录才使用归档日志。 您可以: 配置日志缓冲区和日志文件的大小。 配置日志数。 选择要使用的日志记录类型。 iv.权限权限 权限提供了一种方法来对特权进行分组以及控制实例、数据库和数据库对象的维护和实 用程序操作。用户可以具有提供对一组数据库对象的所有特权的管理权限,他们也可以具有 提供对管理系统的所有特权但是不允许存取数据的系统权限。 sysadm 是最高级别的管理权限。它包括对 db2 实例中的所有数据库的所有特权以及 授予和撤销所有其它权限和特权的权限。 dbadm 提供对特定数据库的管理权限。它允许用户存取和修改该数据库中的所有对象。 具有 dbadm 权限的用户可以对其他用户授予和撤销对数据库的特权,但是不能授予或 撤销 dbadm 权限。 sysctrl 是用于控制数据库管理器所使用的资源(例如,创建和删除数据库)的权限, 但是,不允许存取数据库中的数据。 sysmaint 是用于执行维护操作(例如,启动和停止 db2 服务器以及备份和复原数据 库)的权限。它不允许存取数据库中的数据。 通过将数据库级别的 load 权限与对表的 insert 特权结合起来,可允许用户将数据装入 到该表中。 特定于数据库的权限存储在数据库目录中;而系统权限存储在实例的数据库管理器配置文件 中。 v. 特权特权 topsoft 特权通过已授权用户的授权标识来转移他们的权利,以便对特定对象执行特定操作。它 使该授权标识能够创建、修改或存取某些数据库资源。授权标识可以代表用户、组或所有用 户(public) 。 特权使用户能够创建或存取数据库资源。权限提供了一种方法来对特权进行分组以及控 制实例、数据库和数据库对象的维护和实用程序操作。 可以保持对许多数据库对象(例如数据库、模式、表空间、表、视图、服务器、程序包 和索引)的特权。以下列表是可用于某些对象的一些特权的样本: connect 允许用户存取数据库。 createin 允许用户在模式中创建对象。 use 允许用户在表空间中创建表。 index 允许用户创建表的索引。 delete 允许用户删除表或视图中的行。 execute 允许用户执行程序包。 control 是对一些数据库对象的主要特权。 grant 上的 with grant 选项允许用户将特权授予其他用户。 具有 sysadm 或 dbadm 权限或者 control 特权的用户可以使用 grant 和 revoke sql 语句来显式地授予和撤销特权。 还可以隐式授予特权(即,当显式地为用户授予某些较高级别的特权时) 。还可以为具有 特权执行程序包的用户授予隐式特权。例如,当用户执行涉及到其它特权的程序包时,仅当 执行该程序包时用户才能获得那些特权。他们不需要显式特权就可以直接使用该程序包所使 用的数据对象。 可以使用组来为一组用户提供权限,而不需要对每个用户单独授予或撤销特权。然而, 除了称为 public 的预定义组之外,不能在静态 sql 中或者创建对象(例如,触发器和视 图)时使用组特权。 vi.配置参数配置参数 配置参数会影响数据库或数据库管理器的运行特征。它们存储在配置文件中。 数据库管理器配置文件是在创建 db2 实例时创建的。它包含的参数将影响实例级别的 系统资源,这与是该实例的一部分的任何一个数据库都无关。可以将这些参数中许多参数的 值在系统缺省值的基础上进行更改,以便提高性能或者增大容量,这取决于系统的配置。服 务器和客户机上都存在数据库管理器配置参数。在客户机上可用的参数是可以在服务器上设 置的数据库管理配置参数的子集。 数据库配置文件是在创建数据库时创建的,并且驻留在数据库所驻留的地方。每个数据 库都有一个配置文件,或者在分区环境中,每个数据库分区都有一个配置文件。文件的参数 指定分配给每个数据库的资源数量,这只是其中之一。可以更改许多参数的值以提高性能或 增大容量。可能需要进行不同的更改,这取决于特定数据库中的活动类型。 您可以: 使用控制中心、 “命令行处理器” 、 “应用程序编程接口” (api) 、 “配置助手”和命令中心 来查看、更新和复位服务器的数据库管理器配置参数。 使用“配置助手” 、 “命令行处理器”和“命令编辑器”来查看、更新和复位客户机的数据库 管理器配置参数。 使用控制中心、 “命令行处理器”或“应用程序编程接口” (api)来查看、更新和复位数 据库配置参数。 topsoft vii.系统目录系统目录 系统目录是一些特殊的表,这些表中包含有关数据库中所有对象的信息。这些对象包括, 例如,表、视图、索引以及安全性控件(例如,约束和特定于数据库的权限) 。这些系统目录 表是在创建数据库时创建的。 当创建、改变或删除对象时,db2 将插入、更新或删除目录中用来描述该对象以及该对 象如何与其它对象相关的那些行。目录主要用于只读目的,因为它们是由 db2 来维护的。 通过正常的 sql 查询设施就可获取它们的数据。然而,有一组可更新的特殊目录视图。这 组视图是在用来更新数据库统计信息的目录上定义的。手工更新这些视图可以提供一个影响 系统优化器或者对测试数据库执行实验的方法。 数据库管理器 数据库管理器包括用来存取数据的数据库引擎和设施,例如,命令行处理器和应用程序 接口。 数据库引擎可以管理数据、控制对数据的所有存取权、生成程序包、生成优化路径、提供事 务管理、确保数据完整性和数据安全性,并提供并发性控制。 db2 实例是一种逻辑数据库管理器环境,在该环境中可以对数据库进行编目和设置配置 参数。可以在单个服务器上创建数据库管理器的多个实例,并且可以用于不同的目的,例如, 单独的测试和生产环境。 db2 程序文件以物理形式存储在特定机器的某个位置上。创建的数据库管理器的每个实 例指向该位置,以便使程序文件对于创建的每个实例不会重复。 viii.约束约束 约束是用来确保数据遵守某些限制或规则的一种机制。例如,在一个公司的人力资源数 据库中,每个职员的编号必须是唯一的,因此,应遵守某些约束。db2 提供了下列类型的约 束: 唯一约束保证在与约束相关联的一列或一组列中的值是唯一的,并且表中所有行都不为 空。 主键约束与唯一约束相相似,可以用来定义表之间的关系。 引用约束或外键约束定义表之间和表内的关系。这些关系定义可确保不同表中的相关列 之间的数据值一致。引用约束要求给定属性或表列的所有值在其它一些表或列中也存在。 检查约束是用来指定表中一列或多列的允许值的规则。 not null 约束防止将空值输入列中。 您可以: 在创建表时设置约束。 将约束添加到现有表中。 改变现有表的约束。 从表中删除约束。 打开和关闭对表的约束检查。 topsoft ix.数据完整性数据完整性 当多个用户存取和更改数据时,必须维护关系数据库中数据的完整性。每当数据可以共 享时,都需要确保数据库表中的值的准确性。 您可以: 使用隔离级别来确定在存取数据时数据是如何锁定或者与其它进程隔离开的。 通过定义约束来保护数据和定义数据之间的关系,以强制执行业务规则。 创建可以执行复杂的交叉表数据验证的触发器。 实现恢复策略以保护数据,以便可以将数据复原为一致状态。 x. 主键主键 主键是一种重要的唯一键。它是唯一地标识表中的一行的一列或列组合。 建议为表定义主键,因为唯一地标识每一行可以提高行存取的速度。当定义了主键时,系统 会自动维护对那一组列的唯一索引。 一个表只能有一个主键(虽然它可以具有多个唯一键) 。主键的列不能包含空值。 您可以: 在创建或改变表时定义主键。 改变表时,删除主键。 将主键与外键结合起来使用,以强制引用完整性约束。 xi.外键外键 外键定义两个或多个表之间的关系。它是一个表中的一列或多列,这些列的值与另一个 表中的唯一键或主键相匹配。外键可用来强制表之间的引用约束。 外键使它的表成为另一个表的从属表,从而使另一个表成为父表。 您可以: 创建具有零个或多个外键的表。 在创建或改变表时定义外键。 在改变表时删除外键。 xii.父表父表 父表是这样一种表,它包含一个主键,而另一个表(从属表)中至少有一个外键引用该 主键。在表之间建立这种关系时将强制表之间的引用完整性。 当从父表中删除一行时,db2 将进行检查,以便了解从属表中的任何从属行是否具有相 匹配的外键。在创建外键时,您就指定了要对任何从属行执行的操作。 父表也可能是另一个父表的从属表。 xiii.隔离级别隔离级别 隔离级别确定在存取数据时数据是如何锁定或者与其它进程隔离开的。隔离级别在工作 单元的持续时间内保持有效,除非显式地更改了它。 topsoft 当多个用户存取和更改数据时,必须维护关系数据库中的数据完整性。并发性就是多个 交互式用户或应用程序同时共享资源。隔离级别指定: 应用程序读取和更新的行可用于其它并发执行的应用程序进程的程度。 并发执行的其它应用程序进程的更新活动对应用程序的影响程度。 db2 支持下列隔离级别: 可重复读 在工作单元中锁定了应用程序读取的所有行。因此,当游标打开时,在同一工作单元中 发出了两次的查询每次都会提供相同的结果。在工作单元完成之前,其它应用程序不能更新、 删除或插入会影响结果表的那些行。可重复读的应用程序不能了解其它应用程序未落实的更 改。 读稳定性 读稳定性只锁定应用程序从工作单元中检索到的那些行。它确保在工作单元完成之前, 该工作单元期间进行的任何限定行读取都不会被其它应用程序进程更改,并且,在更改行的 另一应用程序进程落实更改之前,不会读取该进程所更改的任何行。 游标稳定性 当游标定位在由事务存取的某一行时,该行被锁定。在访存下一行或终止事务以前,该 锁定保持有效。然而,如果一行上的任何数据发生更改,则在对数据库落实更改之前,必须 挂起该锁定。结果,在同一工作单元内发出了两次的查询可能不会产生相同的结果。 未落实的读取 应用程序可存取其它事务未落实的更改。除非其它应用程序尝试删除或改变表,否则应 用程序也不锁定其它应用程序存取它正在读取的行。它最常用于对只读表的查询。 您可以: 当准备或绑定应用程序时,指定处于程序包级别的隔离级别。 定义处于语句级别的隔离级别。 xiv.工作单元工作单元 工作单元是应用程序进程中可恢复的一系列操作。数据库管理器使用它来确保数据库处 于一致状态。对数据库的任何读取或写入操作都是在工作单元中完成的。其它数据库产品可 能使用术语 事务 而不是工作单元。 当读取或写入数据库中的任何数据时,就会隐式地启动工作单元。由同一应用程序执行 的所有后续读写操作被认为是同一工作单元的一部分,直到应用程序执行 commit 或 rollback 语句为止,这两个语句将结束工作单元。commit 语句使得在工作单元中所作 的所有更改成为永久性更改。rollback 语句从数据库中除去这些更改。如果应用程序在 没有显式发出这些语句的情况下正常结束,则会自动落实工作单元。如果应用程序在工作单 元中异常结束,则会自动回滚工作单元。 工作单元没有任何物理表示法,因为它是一系列指示信息(sql 语句) 。 锁定 在并发处理期间,数据库管理器使用锁定来维护数据完整性。锁定是数据库对象与应用 程序之间的关联。这种关联允许应用程序控制其它应用程序可以如何存取对象。认为应用程 序保持或者拥有对对象的锁定。 由于并发处理允许多个应用程序同时存取同一数据库,所以数据库管理器由于下列原因 而强加锁定: topsoft 为了保证应用程序保持对对象的控制,直到应用程序完成它的工作为止。这可以防止另 一个应用程序在完成正在进行的工作之前更改对象中的数据。 为了禁止应用程序存取由保持锁定的应用程序所写入的未落实的数据。这保护了数据完 整性。 在大多数情况下,不需要执行操作来控制锁定。在需要时,数据库管理器对一些对象 (例如,行、表和表空间)强加锁定。 xv.连接连接 在使用数据库之前,用户或应用程序必须与该数据库建立连接。连接至数据库并连接至 实例。 您可以: 使用“配置助手”来配置数据库连接。 使用控制中心来连接至数据库。 控制授权连接至数据库的用户和应用程序。 通过在控制中心中打开“连接”文件夹来查看与数据库相连的对象。 使用事件分析器查看连接活动。 xvi.数据安全性数据安全性 两种安全级别可以控制对 db2 通用数据库数据和函数的存取权。对 db2 的存取是由特 定于操作环境(认证)的设施来管理的,然而在 db2 中的存取是由数据库管理器(授权) 来管理的。 认证就是系统验证用户标识的过程。用户认证是由 db2 外部的安全性设施(通常是操 作系统的一部分或者一个独立产品)完成的。 一旦认证了用户,数据库管理器用户就会确定是否允许用户存取 db2 数据或资源。授 权是这样一种过程:db2 通过授权可以获取有关所认证的用户的信息,这些信息指示用户可 以执行哪些数据库操作以及用户可以存取哪些数据对象。授权标识指定已授权用户的存取权。 权限可以分为两种类别:特权和权限。 特权使用户能够创建或存取数据库资源。权限提供了一种方法来对特权进行分组以及控 制实例、数据库和数据库对象的维护和实用程序操作。 xvii. 恢复恢复 恢复就是在出现问题之后(例如,介质或存储器故障、电源中断或应用程序故障) ,重新 构建数据库或表空间。如果已经对数据库或个别表空间进行了备份,则可以在它们因某些原 因而损坏或毁坏时重新构建它们。 有三种类型的恢复: 崩溃恢复,防止
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年中国激光功率监视器行业市场发展前景及发展趋势与投资战略研究报告
- 脑梗死护理指南
- 理财培训课件
- 2025-2030年中国140g瓦楞纸箱行业深度研究分析报告
- 中国浓缩鱼油软胶囊行业市场深度研究及投资战略规划建议报告
- 切朴机行业深度研究分析报告(2024-2030版)
- 中国六角钻尾钉行业市场发展前景及发展趋势与投资战略研究报告(2024-2030)
- 2025年 宜昌市市级机关遴选考试笔试试题附答案
- 2025年 湖南大学幼儿园招聘考试笔试试题附答案
- 2025-2030年中国盐基青莲粒行业深度研究分析报告
- 无人机培训计划及方案
- 临终关怀中的文化敏感性
- 河湖生态系统保护与修复工程技术导则
- 运动改造大脑阅读记录
- H 30014-2013 生产区域吊装作业安全规范
- DL∕T 2011-2019 大型发电机定子绕组现场更换处理试验规程
- 从黄土高原视角品黄河生态变迁智慧树知到期末考试答案章节答案2024年西北工业大学
- 电通量高斯定理课件
- 广东省东莞市2023-2024学年高二下学期7月期末英语试题
- 2024年云南省职业院校技能大赛(中职组)植物嫁接赛项考试题库(含答案)
- 河北省建设项目概算其他费用定额
评论
0/150
提交评论