第1讲 DB2产品简介
DB2数据库目录结构及其作用
DB2数据库目录结构及其作用我创建的数据库存储在什么地方从DB2的架构上来看,DB2 中的数据库的层次位于实例之下。
实例实际上就是一个逻辑的数据库管理器,它提供了一个相对独立的运行环境。
数据库必须要被创建在某个实例之下,因此,在创建数据库之前,必须要先创建实例。
每当一个新的实例被创建,DB2都会在DB2安装目录sqllib 下生成一个目录,其目录名称与实例名称相同,该目录下的文件用于对该实例进行管理和控制。
另外,在使用CREATE DATABSE创建数据库之后,系统还将会生成一系列子目录,具体的目录结构如图1所示。
图1:数据库缺省目录结构在图1中,"驱动器/目录"的具体值可以在CREATE DATABASE 命令中指定(对于Windows 平台,用户只能指定要创建数据库的驱动器;而对于Unix/Linux 平台,用户可以指定在哪个目录下创建数据库),如果没有在创建数据库的时候指定路径,系统将会在数据库管理器配置参数DFTDBPATH 指定的缺省路径下来创建相应目录。
第一层子目录的目录名与实例名称相同,属于该实例的数据将会被存储在该目录下。
第二层子目录指定了该数据库所属的数据库分区。
在DB2 V8中,数据库分区取代了以前版本中的节点的概念。
一个数据库分区是数据库的一个子集,拥有自己的配置文件、数据、索引和日志。
在多分区数据库环境下,一个数据库可以被划分为多个分区,不同的分区可以驻留在不同的物理机器上,从而提高整个数据库系统的处理能力。
在这种环境下,每个分区都有自己的编号,这个编号会体现在数据库的目录结构中。
比如,如果该分区的编号为3,则该层目录名称应为NODE0003。
对于单分区数据库环境,该目录名固定为NODE0000。
接下来名称形如"SQL0000n"的目录对应着该实例下的相应数据库。
数据库中的数据就存放在该目录下。
在该实例下创建的第一个数据库对应的目录为SQL00001,第二个为SQL00002,依此类推。
IBM DB2
IBM DB2学习笔记DB2数据库的体系结构在DB2数据库中,最大的概念是系统(节点)也就是主机,系统下面是实例,实例下面是数据库,然后是表空间,然后是数据库对象。
系统:整个DB2环境。
实例:一个逻辑数据库管理器环境,可在其中编目数据库并设置配置参数。
根据需要,可创建多个实例。
每一个实例都是一个完整的环境,它有独立的安全性,不受同一机器(系统)上其他实例的影响。
每一个实例都对应一个实例目录,实例目录存储着与一个实例相关的所有信息。
该目录包含:数据库管理器配置文件、系统数据库目录、节点目录、节点配置文件(db2nodes.cfg)、包含调试信息的任何其它文件。
在Windows操作系统上,该实例目录位于/sqllib子目录,即安装DB2的目录。
在安装期间,要创建一个DB2的初始实例,称为“DB2”。
数据库:关系数据库将数据表示成表的集合。
表由数目已定的列和任意数目的行组成。
数据库分区组:数据库分区组是一个或多个数据库分区的集合。
(我们一般使用的是单分区数据库,数据库分区组涉及到并行数据库系统,此处我们不详细讨论)表空间:数据库由称为表空间的部件组成。
表空间是用来存储表的位置。
当创建表时,您可以决定将特定对象(如索引和大对象(LOB))数据与其余表数据分开存放。
表空间也可以分布在一个或多个物理存储设备上。
启动DB2 db2start停止DB2 db2stop有时还存在一些活动,需要强制停止,用db2stop force信息帮助(db2 ? XXXnnnnn)db2 ? create db2 ? sql1005 查询错误提示创建数据库db2 create db mydb2db2 create db mydb on E: alias(别名) mydb2连接数据库db2 connect to ncgl user gever(用户)using gevermis(密码)只有连接数据库后,才能进行相应的查询、插入等操作删除某张表db2 drop table mytable删除某张表里面的数据db2 delete from mytable查询db2 select * from table_name(sys_parm)显示当前用户所有表(进行显示之前,先进行数据库的连接)db2 list tables显示所有的系统表db2 list tables for system查看表结构db2 describe table mytable(table_name)查看表空间db2 list tablespaces备份数据库db2 backup db mydb2 to D:\恢复数据库流程1、恢复数据:db2 restore db ncgl user gever using gevermis from D:\db2 restore db ncgl user gever using gevermis from D:\ into myncgl(恢复数据库并重命名为myncgl)2、回滚log日志:db2 rollforward db ncgl to end of logs and complete3、连接查看:db2 connect to ncgl user gever using gevermis中断连接db2 connect resetdb2 disconnect ncgldb2 force application all(中断所有连接)列出在活动的数据库和连接数db2 list active databases返回当前连接的应用程序的信息db2 list application列出数据库系统目录db2 list db directorydb2 list db directory on D在本地数据库目录中有而系统数据库目录中没有的数据库不能访问,可以在控制中心中选中<数据库>右键单击选择添加,然后输入需要添加的数据库名称或者点击刷新按钮选择数据库,加入数据库后即可以访问。
DB2基础知识(一)
内部资料 注意保密
12
二、DB2的访问
节点目录、系统数据库目录和本地数据库目录间关系
内部资料 注意保密
13
二、DB2的访问
2.1 DB2的登录
通过本地客户端链接DB2服务器
内部资料 注意保密
14
二、DB2的访问
2.2 SQL语句的执行
内部资料 注意保密
15
二、DB2的访问
2.3 SQLSTATE & SQLCODE
说明
– – –
不能修改视图 视图不能创建索引 如果删除了某视图基于的表或另一视图,则该视图在数据库虽然有定义但不起作用
内部资料 注意保密
35
三、DB2数据库对象
视图
创建可更新视图和只读视图
• • •
视图的 SELECT 语句决定视图是只读的还是可更新的 通常,如果视图的行可映射至基表的行,则视图是可更新的。
显式地指定对象的模式名: create table DWAINE.table1 (c1 int, c2 int) 隐式地指定对象的模式名: create table t2 (c1 int) --- table tjadm.t2 created 注:隐式地指定对象的模式名,用户 需要IMPLICT_SCHEMA 特权
内部资料 注意保密
11
二、DB2的访问
2.1 DB2的登录
通过本地客户端链接DB2服务器
安装本地DB2客户端程序 配置本地Catalog(编目)
Db2cmd->db2 connect to bidbdw user scvadm
catalog tcpip node mynode remote 99.1.57.103 server 50000; catalog db bidbdw at node mynode;
db2参数大全(共5篇)
db2参数大全(共5篇)第一篇:db2参数大全•参数名称说明DB2CODEPAGE 为数据库客户机应用程序指定呈示给DB2 的数据的代码页DB2COUNTRY 指定客户机应用程序的国家或地区、地域或区域代码DB2_PINNED_BP 用于指定在某些 AIX 操作系统上与主存中的数据库关联的数据库全局内存(包括缓冲池)DB2_PARALLEL_IO 用来更改 DB2 计算表空间的 I/O 并行性的方式DB2ATLD_PORTS 用于指定LOAD操作所使用的通信端口范围DB2_HASH_JOIN 将散列连接指定为当编译存取方案时可能的连接方法DB2MEMDISCLAIM 控制 DB2 代理进程是否显式请求 AIX 从释放的内存中解除关联保留的调页空间DB2MEMMAXFREE 指定未使用的专用内存的最大字节数,在将未使用的内存返回到操作系统之前该字节数由 DB2 进程保留DB2_FORCE_FCM_BP 指定DB2 从数据库全局内存中或从单独的共享内存段(如果没有足够的全局内存可用)分配 FCM 缓冲区DB2DBDFT 指定用于隐式连接的数据库的数据库别名DB2COMM 指定当启动数据库管理器时所启动的通信管理器DBM CFG参数名称说明DFT_MON_BUFPOOL 快照监视器的缓冲池开关的缺省值DFT_MON_LOCK 快照监视器的锁定开关的缺省值DFT_MON_SORT 快照监视器的排序开关的缺省值DFT_MON_STMT 快照监视器的语句开关的缺省值DFT_MON_TABLE 快照监视器的表开关的缺省值DFT_MON_TIMESTAMP 快照监视器的时间戳记开关的缺省值DFT_MON_UOW 快照监视器的工作单元(UOW)开关的缺省值HEALTH_MON 指定是否想要根据各种健康指示器来监视实例、它的相关数据库和数据库对象SYSCTRL_GROUP 定义具有系统控制(SYSCTRL)权限的组名SYSMAINT_GROUP 定义具有系统维护(SYSMAINT)权限的组名 SYSMON_GROUP 定义具有系统监视(SYSMON)权限的组名NUM_POOLAGENTS 确定空闲代理进程池的最大大小DFTDBPATH 指定在数据库管理器下创建数据库的缺省文件路径MON_HEAP_SZ 确定分配给数据库系统监视器数据的内存量JAVA_HEAP_SZ 确定由已启动以便为 Java DB2 存储过程和 UDF 提供服务的 Java 解释器使用的堆的最大大小SHEAPTHRES 定义排序堆的阈值QUERY_HEAP_SZ 指定可为查询堆分配的最大内存容量MAXAGENTS 指定可在任何给定时间接受应用程序请求的数据库管理器代理进程(无论是协调代理进程还是子代理进程)的最大数目NUM_POOLAGENTS 确定空闲代理进程池的最大大小NUM_INITAGENTS 确定在 DB2START 时在代理进程池中创建的初始空闲代理进程数SVCENAME 数据库服务器将用于等待来自远程客户机节点的通信的 TCP/IP 端口的名称MAX_QUERYDEGREE 指定用于在数据库管理器的此实例上执行的任何 SQL 语句的最大分区内并行度INTRA_PARALLEL 指定数据库管理器是否可以使用分区内并行性FCM_NUM_BUFFERS 指定数据库服务器之间及内部用于内部通信(消息)的 4 KB 缓冲区数DB CFG参数名称说明DFT_QUERYOPT 指定查询优化级别用于指导优化器使用不同程度的优化DFT_DEGREE 指定 CURRENT DEGREE 专用寄存器和 DEGREE 绑定选项的缺省值DBHEAP 制定数据库堆的大小CATALOGCACHE_SZ 指定用于高速缓存系统目录信息的内存大小LOGBUFSZ 指定用作日志记录的缓冲区的数据库堆阵的容量UTIL_HEAP_SZ 指定实用程序堆的大小LOCKLIST 指示分配给锁定列表的内存量APPGROUP_MEM_SZ 确定应用程序组共享内存段的大小GROUPHEAP_RATIO 指定用于应用程序组共享堆的应用程序控制共享内存集中的内存百分比APP_CTL_HEAP_SZ 指定分配给应用程序的共享内存区域的平均大小SHEAPTHRES_SHR 指定对可一次用于排序的数据库共享内存总量的硬限制SORTHEAP 定义要用于专用排序的专用内存页的最大数目或要用于共享排序的共享内存页的最大数目STMTHEAP 语句堆在 SQL 语句的编译期间用作 SQL 编译器的工作空间,此参数指定此工作空间的大小APPLHEAPSZ 指定代理进程或子代理进程使用的专用内存页数目PCKCACHESZ 指定用于高速缓存数据库上的静态和动态SQL 语句的内存的大小STAT_HEAP_SZ 参数指示使用 RUNSTATS 命令收集统计信息时所用的堆的最大大小。
db2 syscolumns表结构
DB2(Database 2)是IBM公司开发的一种关系数据库管理系统。
在DB2中,syscolumns是一个非常重要的系统表,它存储了数据库中表的结构信息。
本文将详细介绍DB2中syscolumns表的结构,并给出一些常见的用法和注意事项。
一、syscolumns表的结构1. 列名(colname):该列存储了表中所有列的名称。
2. 列序号(colno):该列存储了表中所有列的序号,从1开始递增。
3. 列所属的表名(tabname):该列存储了每个列所属的表的名称。
4. 列所属的模式名(tabschema):该列存储了每个列所属的表的模式名称。
5. 列类型(typename):该列存储了每个列的数据类型,如varchar、int等。
6. 列长度(length):该列存储了每个列的长度。
7. 列精度(scale):该列存储了每个列的精度。
8. 默认值(default):该列存储了每个列的默认值。
9. 是否可为null(nulls):该列存储了每个列是否允许为空值,是一个布尔值。
二、syscolumns表的用法在实际的数据库管理中,syscolumns表有很多用途。
以下是一些常见的用法:1. 查询表的列信息:通过在syscolumns表中查询特定表的列信息,可以方便地了解表的结构,包括列名、数据类型、长度等。
2. 检查列的默认值和是否允许为空:通过syscolumns表,可以查看每个列的默认值和是否允许为空,从而更好地理解表的设计意图。
3. 维护数据库的元数据:DBA可以通过syscolumns表来维护数据库的元数据,如跟踪表结构的变化、识别潜在的性能问题等。
三、syscolumns表的注意事项在使用syscolumns表时,需要注意一些事项:1. 需要有足够的权限:要查询syscolumns表,用户需要有足够的权限,通常是DBA或者有相应权限的用户。
2. 不要直接修改syscolumns表:syscolumns表是系统表,不建议直接对其进行修改,以免造成数据库结构的混乱。
DB2数据库培训教材
Copyright © 2006 Sihitech Co. - All Rights Reserved
北京宇信鸿泰软件技术有限公司
DB2 安装
选择“下一步”。
Copyright © 2006 Sihitech Co. - All Rights Reserved
北京宇信鸿泰软件技术有限公司
DB2 安装
Copyright © 2006 Sihitech Co. - All Rights Reserved
北京宇信鸿泰软件技术有限公司
恢复数据库到本地
从开始菜单上选择“开始->IBM DB2->命令行工具->命令窗 口”,并切换到E:\crmdb目录下。 执行“db2 -tf crmcs_rr2.sql”。
北京宇信鸿泰软件技术有限公司
DB2 概述
DB2是IBM公司的一个关系型数据库产品。 DB2可以运行在AS400、S390、UNIX、Windows等平台上。 DB2的手册、参考等文档可以从IBM的官方网站下载。 在建行OCRM项目中,因为该项目所使用工作流软件S1的原 因,数据库产品选择了DB2。
北京宇信鸿泰软件技术有限公司
DB2 安装
接受默认值。选择“下一步”。
Copyright © 2006 Sihitech Co. - All Rights Reserved
北京宇信鸿泰软件技术有限公司
DB2 安装
接受默认值。选择“下一步”。
Copyright © 2006 Sihitech Co. - All Rights Reserved
北京宇信鸿泰软件技术有限公司
DB2 安装
DB2使用手册
DB2使⽤⼿册第⼀部分DB2系统管理命令1. Db2有域,实例,和数据库三层的概念。
2.查看数据库服务器中有⼏个数据库。
包括⽹络中数据库的引⽤。
进⼊数据库安装⽬录下的bin⽬录:C:\Program Files\IBM\SQLLIB\BIN执⾏db2 list database directory命令3.查看命令选项说明list command options4.查看运⾏的数据库服务器中关联了多少个引⽤程序对数据库的访问。
进⼊数据库安装⽬录下的bin⽬录:C:\Program Files\IBM\SQLLIB\BINdb2 list applications命令可以通过db2 force application(进程id) 杀死对应的进程。
5.如何强制断开应⽤程序和数据库的连接。
进⼊数据库安装⽬录下的bin⽬录:C:\Program Files\IBM\SQLLIB\BIN⾏下列的命令 db2 force applications 可以强制断开应⽤程序和数据库的连接。
6.如何备份数据库进⼊db2的操作环境,然后运⾏backup database 数据库别名 user ⽤户名 using 密码命令7.停⽌数据库的服务器。
进⼊数据库安装⽬录下的bin⽬录:C:\Program Files\IBM\SQLLIB\BIN或db2操作环境中,如果在db2操作环境中必须通过的db2 terminate命令终结db2操作环境中启动的所有⼦进程(即停⽌所有命令⾏处理器回话)再执⾏db2stop命令。
注意:在执⾏此命令的时候,必须没有应⽤程序或⽤户和数据库连接。
可以在执⾏停⽌命令之前查看于db2服务器连接的应⽤程序和⽤户。
然后执⾏牵制断开命令断开连接的数据库和⽤户。
8.如何从旧版本中把数据库迁移到新的安装版本中(在新版数据库种运⾏下列代码)1. 验证数据库是否可以被迁移。
⽤db2ckmig命令,db2ckmig /e 数据库别名 /l 验证信息保存路径 /u ⽤户名 /p 密码1. 执⾏数据库的迁移命令MIGRATE database 数据库别名 user ⽤户名 using 密码命令9.启动DB2服务器进⼊数据库安装⽬录下的bin⽬录:C:\Program Files\IBM\SQLLIB\BIN或db2操作环境中执⾏db2start命令10.关于命令⾏编辑器的使⽤使⽤命令⾏编辑器之前要连接到⼀个数据库。
DB2基础知识
BSDS
系统下包含了一整套系统文件、一套
系统数据库和用户定义的多个
系统 数据库
应用 数据库
应用数据库
■ DB2 Object
CATALOG
DB2 SUBSYSTEM
DIRECTORY OTHER SYSTEM OBJECTS
DATABASE 1
TABLE SPACES1
DATABASE2.etc.
■分区表空间
某个分区可以STOP,不影响其它分区
上例中,STOP 0300—0399:天津地区 有交易查询: WHERE ZONENO=200 因没有涉及到0300-0399分区,查询交易仍然可以成功
■ PARTITION表划分原则
数据量过大的表(超过2G) 并行批量程序涉及的表
■顺序预取 SEQUENTIAL PREFETCH
用于读取连续的页 既可用于在TABLE SPACE SCAN中访问连续的数 据页,也可用于在INDEX SCAN中访问连续的数 据页和索引页 页 页 页 页
页 页 页 页 页 页 页 页 页 页 页 页 页
单个I/O
单个I/O
页
页
页
页
页
页
页
页
TABLE SPACES2
STORAGE GROUP1 VOLUME1 VOLUME2
TABLE1
INDEX1 VIEW1
TABLE2. etc.
INDEX2.etc. VIEW2 VIEW3.etc STORAGE GROUP2 VOLUME3
■ DB2 Objects 概述
■ PARTITION TABLESPACE 的缺点
db2数据库基础知识
db2数据库基础知识1,db2数据库特点(1)具有很好的并⾏性(DB2把数据库管理扩充到了并⾏的,多节点的环境;数据库分区是数据库的⼀部分,包含⾃⼰的数据,索引,配置⽂件和事务⽇志;数据库分区有时被称为节点)。
(2)获得最⾼认证级别的ISO标准认证。
(3)性能较⾼,适⽤于数据仓库和在线事物处理。
(4)跨平台,多层结构,⽀持ODBC,JDBC等客户。
(5)操作简单,同时提供GUI和命令⾏,在windowsNT和unix下的操作相同。
(6)在巨型企业得到⼴泛的运⽤,向下兼容性好,风险⼩。
(7)能够在所有主流平台上运⾏,最适于海量数据处理。
2,db2数据库的特性(1)完全Web使能的:可以利⽤HTTP来发送询问给服务器。
(2)⾼度可缩放和可靠:⾼负荷时可利⽤多处理器和⼤内存,可以跨服务器地分布数据库和数据负荷;能够以最⼩的数据丢失快速地恢复,提供多种备份策略。
3,实现储存过程存储过程是存储在数据库中的⼀个预编译对象。
这意味着过程是预编译的,可提供给各种应⽤执⾏。
发送查询到服务器、分析和编译过程再不需要花费时间。
(1)特点:存储过程是SQL语句和控制流语句的⼀个集合或批量,它在⼀个名称下存储,按独⽴单元⽅式执⾏。
它能帮助提⾼查询的性能。
(2)好处:提⾼性能(应⽤不必重复地编译此过程)减轻⽹络拥塞(为进⾏处理,应⽤不需要向服务器提交多个SQL语句)⼀致性较好(由于过程作为单⼀控制点,在过程中定义的编码逻辑和SQL语句在所有应⽤中被⼀致地实现)改善安全机制(⽤户可以被授予许可权来执⾏存储过程,尽管他们并不拥有这个过程)(3)执⾏存储过程语句:call proc_name(param,…)(4)RETURN关键字:允许存储过程把整型值返回给调⽤者。
如果没有指定值,那么存储过程返回缺省值0或1,这依赖于存储过程的成功执⾏与否。
RETURN value(5)嵌套过程:可以执⾏或调⽤来⾃另⼀个过程的过程。
4,触发器触发器:⼀个触发器是由SQL语句集组成的代码块,在响应某些动作时激活该语句集。
DB2基本知识
Compile and Linkedit
Load MODULE
When executing , system will check the Timestamp(Consistency Token) of Load MODULE and Plan which is made by Pre-compiler.
17 2010-11-17
Coding Aids
DSNTIAR/DANTIR
SQL错误返回代码解释例程,在应用程序中调 用该例程以获得系统标准的错误解释。 CALL DSNTIAR
DCLGEN
根据DB2中的Table定义将表的定义描述生成 到指定的数据集中。
Include statement
18 2010-11-17
OPEN the CURSOR
----
Execution
EXEC SQL OPEN K9 END-EXEC.
FETCH RESULT ROWS ONE AT A TIME
EXEC SQL FETCH K9 INTO :EMPNO,:NAME END-EXEC.
CLOSE CURSOR when finished
IMS Attach
2 2010-11-17
DB2 Object
CATALOG
DB2 SUBSYSTEM
DIRECTORY OTHER SYSTEM OBJECTS
DATABASE 1 TABLE SPACES1
DATABASE2.etc. TABLE SPACES2
STORAGE GROUP1 VOLUME1 VOLUME2
13 2010-11-17
Cursors
在查询数据库可能返回多条数据记录时, 使用“游标”(Cursors)来完成对记录 的处理。使用的语句包括: DECLARE -声明一个游标 OPEN -打开游标 FETCH -读取游标中的一条记录 CLOSE CURSOR -关闭游标
IBM DB2 UDB 产品说明
IBM DB2 UDB产品介绍IBM DB2 UDB产品介绍前言数据库管理系统,尤其是关系型数据库,与IBM数据库有着不可分割的关系。
三十多年来从理论研究到具体的系统实现,IBM数据库研究人员对数据库管理系统的发展作出了极大的贡献。
70年代之前,数据库中的数据结构以层次型(如IBM IMS数据库)及网络型为主。
在这些数据库中记录与记录之间往往存在着指针(pointers)以方便应用程序搜寻有关联的数据。
1970年IBM数据库研究中心的E.F.Codd博士在其论文[Codd70]中提出了关系型的数据库模式。
在这创新的理论中记录与记录的关系建立在它们共享的数值上而非基于隐藏的指针。
数据库的查询因而可以用非过程化(nonprocedural)的语句表达。
Codd同时证明了用一阶谓词逻辑微积分(first-order predicate calculus)等数学理论作为非过程化语句基础的可能性,并进一步地发展了关系微积分(relational calulus[Codd71a])与关系代数(relational algebra[Codd71b]),奠定了关系型数据库日后发展的理论基础。
为此E.F.Codd博士在1981年得到了计算机科学界的最高荣誉奖ACM图灵奖(ACM Turing Award)。
1973年位于美国加州圣荷西市的IBM数据库研究中心开始了一个大的关系型数据库系统研究项目System R[Astrahan 76],探讨并验证在多用户与大量数据下关系型数据库的实际可行性。
System R对关系型数据库的商业化起着关键性的催化作用。
在D.Chamberlin博士的领导下System R的一个研究小组发明了一套比关系微积分与关系代数更适合最终用户使用的非程序化查询语言SQL[Chamberlin74,76,80]。
SQL的设计宗旨是面向最终用户,达到简单,易学,易用。
并且,SQL把早期数据管理系统中各种独立的功能如查询,数据修改,数据定义和控制等整合到一个单一的语言环境内。
IBMDB2UDB介绍
TP
将所有行放在同一个数据 数据移动 —— 通过添加和删除整个数 分区的一个指定范围的维 据分区,可以增加和删除大量数据 中
Page16
事实表拥有适合使用 DB2 分区特性的特征
特性 DPF 适合的表特征 大型表 —— 大到无法仅依 靠单独一组 CPU 和 I/O 通 道来处理 事实表的特征 事实表是最大的数据库表。它们常常 包含数亿行数据,有时候甚至包含数 千亿行数据
IBM DB2 UDB介绍 介绍
2008年12月6日 年 月 日 河北移动经分项目组
HUAWEITECHNOLOGIESCo.,Ltd.
HUAWEIConfidential
DB2产品家族 产品家族
DB2 的各个版本从低到高依次为: DB2 Everyplace DB2 Express DB2 WorkGroup DB2 Enterprise DB2 Data WareHouse Enterprise 每个版本都包含前一个版本的所有特性 和功能,并添加了新特性和新功能。 DB2 在 AIX、Windows 和 UNIX 、Linux 平台上的代码大约有 90%是相同的,另有10%的专用代码, 用于使数据库和底层操作系统紧密sional Clustering 多维集群:
一个表,其数据按 ORGANIZE BY DIMENSIONS 子句中指定的一个或多 个维或者集群键以物理方式组织成块。 MDC 是在 DB2 Version 8 中引入的,通过它可以在物理上将在多个维上 具有类似值的行聚合在一起放在磁盘上。这种聚合能为常见分析性查询 提供高效的 I/O。例如,对于 Product=car,Region=East,并且 SaleMonthYear = Jan09 的所有行,可以将它们存储在相同的存储位置, 即所谓的块(block)。在 CREATE table 语句中定义维的时候,就为每 种值的组合预留了存储空间。实际上,MDC 是一个能最大化查询性能的 特性,对于数据仓库中常用的查询更是如此。这包括需要根据几个列中 的值的组合选择行的查询。例如,DATE is between "Jan-01-2004" and "Feb-01-2005" AND Country IS NOT "United States" AND Product="Cell Phones"。
DB2的命令行工具
DB2UDB 命令行工具DB2UDB 命令行工具是DB2UDB 的组件,这些工具支持对DB2命令以及 SQL 语句的处理。
在Windows 上可使用三种命令行工具:DB2命令中心(Command Center)DB2命令行处理器(CLP)DB2命令窗口您可以通过单击Start -> Programs -> IBM DB2-> Command Line Tools找到这些工具。
DB2命令中心第一个命令行工具是DB2命令中心(图1),它提供一个处理命令和SQL 语句的GUI。
您可以用交互方式或脚本(批处理)方式工作,或者将两种方式结合使用。
通过单击Start -> Programs -> IBM DB2-> Command Line Tools -> Command Center启动DB2命令中心。
图 1. DB2命令中心图1是DB2命令中心的抓屏。
在本例中,我们导入了如清单1所示的样本DB2备份脚本。
您可以通过从Script菜单选择Import来导入脚本。
DB2命令行处理器(CLP)一般而言,可以把DB2命令行处理器(CLP)当作用于调用DB2命令的DB2提示符DB2=>,就象Windows 命令提示符 C:用于调用操作系统命令一样。
也可以从任一DB2命令行工具调用DB2系统命令(稍后讨论)和操作系统命令,只要在命令前加一个感叹号!即可。
图2显示了DB2CLP 以及关于如何获取DB2命令帮助的一些基本信息。
单击Start -> Programs -> IBM DB2-> Command Line Tools -> Command Line Processor,启动DB2CLP。
图 2. DB2命令行处理器要了解有关DB2UDB V8.1 中DB2CLP 新增功能的更多信息,请阅读Paul C. Zikopoulos 撰写的DB2开发者园地文章定制DB2通用数据库命令行处理器。
DB2介绍和安装
DB2介绍和安装DB2 LUW(IBM DB2 Database for Linux 、UNIX and Windows ,本后续章节中,本书统一简写为DB2)是IBM 于1983年推出的第一款面向大型企业的商业化关系数据库管理系统。
在20世纪80年代初,DB2的发展重点放在大型的主机平台,从80年代中期到90年代初,DB2已发展到中型机、小型机以及微机平台。
DB2的诞生不仅促进了与关系数据库概念相关的数学和科学的发展,还创造性地开发出一种极具影响力的全新软件类型。
今天,DB2已经发展成为IBM 信息管理(IM)软件组合的重要组成部分。
在IBM 信息随需应变策略和体系结构中,DB2扮演数据基础服务平台的重要角色,并且已经发展成同时支持传统关系数据和XML 的混合型数据服务器。
传承IBM 数据库的优良传统并具有突破性的数据库产品DB2 LUW V10.1已经于2012年4月份问世,它在原有V9版本的基础上,增加了众多革命性的技术,使DB2 LUW 产品在多个领域实现了突破。
DB2数据库产品及解决方案广泛应用在金融、电信、制造、零售、保险等行业及政府机关,以数据库技术创新帮助客户实现更大价值,以技术创新推动商业模式的变革和不断发展。
本章主要讲解如下内容:● DB2数据库概述● DB2数据库的安装和配置● DB2数据库的体系结构1.1 DB2数据库概述1.1.1 DB2发展历史我们都知道DB2是关系型商用数据库的一种,那么在开始学习DB2之前,先来了解一第 章 1下数据库的发展历史。
1. 数据库的发展历史在没有数据库之前,人们靠什么来记录数据呢?最早是靠文件,但是用文件记录有很多缺点,例如不易保存和共享等,而数据库的出现可以解决这些问题。
数据库的历史可以追溯到40多年前,当时计算机开始广泛地应用于数据管理,对数据的共享提出了越来越高的要求。
传统的文件方式已经不能满足人们的需要。
能够统一管理和共享数据的数据库管理系统(DBMS)应运而生。
db2表空间详解
3.2 表空间设计3.2.1 创建表空间表空间建立数据库系统使用的物理存储设备与用来存储数据的逻辑对象或表之间的关系。
对于非自动存储器表空间,在创建表空间时,必须知道将引用的容器的设备名或文件名。
另外,必须知道与要分配给表空间的每个设备名或文件名及分配空间大小。
对于自动存储器表空间,数据库管理器将根据与数据库关联的存储路径将容器指定给表空间。
在一个数据库内创建表空间,会将容器分配到表空间,并在数据库系统目录表中记录它的定义和属性,然后就可以在此表空间内创建表。
当创建数据库时,会创建3个初始表空间。
这3个初始表空间的页大小基于使用CREATE DATABASE命令时建立或接受的默认值。
此默认值还表示所有将来CREATE BUFFERPOOL和CREATE TABLESPACE语句的默认页大小。
如果在创建数据库时不指定页大小,那么默认大小是4KB。
如果在创建表空间时不指定页大小,那么默认页大小是创建数据库时设置的页大小。
创建表空间可以通过控制中心或命令行创建。
一、使用控制中心创建表空间使用控制中心创建表空间二、使用命令行创建表空间1.创建用户表空间创建SMS表空间:CREATE TABLESPACE <NAME> MANAGED BY SYSTEM USING (‘<path>’)创建DMS表空间:CREATE TABLESPACE <NAME> MANAGED BY DATABASE USING(DEVICE |FILE’<path>’<size>) 创建自动存储器表空间CREATE TABLESPACE <NAME>或CREATE TABLESPACE <NAME> MANAGED BY AUTOMATIC STORAGE例:1.在Windows上,使用3个不同的驱动器上的目录,创建SMS表空间CREATE TABLESPACE TS1 MANAGED BY SYSTEMUSING (‘d:\nxz_tbsp’,’e:\nxz_tbsp’,’f:\nxz_tbsp)2.使用各自有5000页的两个文件容器创建了一个DMS表空间:CREATE TABLESPACE TS2 MANAGED BY DATABASEUSING (FILE’d:\db2data\acc_tbsp’ 5000,FILE’e:\db2data\acc_tbsp’ 5000)在创建DMS表空间时,表空间文件容器不需要重建,DB2自动来创建,但裸设备容器无法自动创建,需要root用户参与。
大型机DB2(中文版)
GRANT语句:
GRANT语句用于赋予一个用户或者一个用户组对数据库的访问
权限;
REVOKE语句:
REVOKE语句相当于GRANT语句的逆运算,该语句主要是用于
收回通过GRANT语句赋予的权限;
ROLLBACK语句和COMMIT语句主要用于控制数据操作的执
行流程;
SQLCA:(SQL Communication Area)即SQL通信区域:
注意:在声明游标时,select_statement不能包含INTO子句。当使用
显式游标时,INTO子句是FETCH语句的一部分。
Select code, name From tbl-course Where days>2 and code like ’E%’
SELECT语句中的功能字句:
SUM: 得到所选数据的总和; VG: 得到所选数据的平均值; MIN : 得到所选数据中的最小值; MAX:得到所选数据中的最大值; COUNT(*):得到所选数据的个数;
END-EXEC
利用游标同时处理多行记录
游标用来处理从数据库中检索的多行记录(使用SELECT语句)。
利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录 集。
为了处理SQL语句,将在内存中分配一个区域,这就是上下文区。
这个区包含了已经处理完的行数、指向被分析语句的指针,整个 区是查询语句返回的数据行集。
静态回滚游标
静态回滚游标属于传统的回滚游标 当在程序中打开静态回滚游标后,将会根据游标定义时的选择条件, 创建一张临时的表,作为结果信息表
静态回滚游标又分为不敏感的静态回滚游标和敏感的静态回滚游
标两种
不敏感的静态回滚游标
DB2性能工具简介
在数据库数据页损坏无法进行正常的数据操作时,可以通过db2dart进行数据恢复。当行,则可以在已损坏的表中用 db2dart命令进行数据导出,前提是数据库能连接上。 Db2dart dbname /ddel 然后按提示输入表id,表空间id,起始页,导出页数 Filename used for output data file is TS2T10.DEL. If existing file, data will be appended to it. Formatted data being dumped ... Dumping Page 0 .... Dumping Page 1 .... Table object data formatting end. 导出的数据就在TS2T10.DEL中,以文本形式保存。 由于db2dart命令不需要通过db2数据库管理器进行对数据库的访问,而是直接从磁盘 中读取数据的数据,因此,就算是数据表无法访问,也能进行数据的导出。不过当数 据量大时速度会十分慢。
db2dart 当数据库出现问题的时候,可以用db2dart进行检查,验证数据库以及相关数据库对象是 否正确 db2dart dbname /db Table inspection start: UCAR.TABLE4 Data inspection phase start. Data obj: 7 In pool: 2 Data inspection phase end. Index inspection phase start. Index obj: 7 In pool: 2 Scanning pages for unique index itoken(0) root page:385p. Scanning pages for unique index itoken(1) root page:386p. Index inspection phase end. Table inspection end. ......... Database inspection phase end. ______________________________________ The requested DB2DART processing has completed successfully! All operation completed without error; no problems were detected in the database. ______________________________________ Complete DB2DART report found in: PRODDB.RPT
Db2基本数据类型
DB2的基本数据类型字段类型描述字xx及其缺省值Char(size)用于保存定长(size)字节的字符串数据。
每行定长(不足部分补为空格);最大长度为254字节,缺省值为每行1字节。
Varchar(size)用于保存变长的字符串数据。
其中最大字节长度由(size)指定。
每行长度可变,最大长度为4000字节。
数据长度缺省为1Long Varchar用于保存变长的字符串数据。
每行xx可变,最大xx为字节。
Graphic(size)双字节字符串。
每行定长(不足部分补为空格)。
最大长度为127字节。
Vargraphic(size)可变长,双字节字符串。
每行变长。
最大xx为127字节。
Long Vargraphic双字节字符串。
最大xx为16350双字节字符串。
Timestamp用于改变管理的二进制值数据,包括____年__月__日时分秒毫秒。
字节数为26Date保存定长的日期数据,范围为00年到99。
每行固定为10字节xx。
Time保存定长的时间数据。
每行固定为8字节xx。
Integer保存整型数据,范围为-48到+47。
最大长度为4字节32 - 1字节或4G。
Smallint保存整型数据,范围为-32768到+32767最大长度为2字节32 - 1字节或4G。
Bigint保存整型数据,范围为-808到+807最大xx为2字节64 - 1字节。
Real保存单精度浮点数据类型最大xx为4字节。
指数表示。
Double保存双精度浮点数据类型,范围为-2.23E-308到+2.23E-308。
最大xx为8字节。
指数表示。
Float保存浮点数据类型,范围为-2.23E-308到+2.23E-308。
最大xx为8字节。
指数表示。
Numeric(p,s)保存精确数值数据类型,范围为-10E-38到+10E-38,p是精度,总小数位数(1~38),s是小数位(小数位小于等于p)最大xx为2~17字节。
Decimal(p,s)保存精确数值数据类型,范围为-10E-38到+10E-38,p是精度,总小数位数(1~38),s是小数位(小数位小于等于p)最大xx为2~17字节。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
4/13
UDB支持多种操作系统 DB2 UDB支持多种操作系统
5/13
针对不同用户群体的要求提供不同 级别的产品
6/13
UDB产品组件及其功能 UDB产品组件及其功能
作为一个复杂、庞大而又功能完备的数据库系统,DB2 UDB实际上是不同产品的组合。 DB2 系统可以分为以下7大部分:
DB2引擎 运行客户端 SDK客户端 管理客户端 DB2连接器 DRDA(分布式关系型数据库结构)应用请求端 应用服务器
7/13
UDB产品组件 UDB产品组件
8/13
DB2引擎 DB2引擎
整个数据库系统的核心,提供DB2的基本功能。 负责管理和控制对数据的存取 复杂生成程序包(存储存取计划的数据库对象) 提供事务的管理 保障数据库的完整性和数据保护 提供应用程序并发控制
9/13
运行客户端
运行远程应用程序对数据库服务器进行存取 组件中包含了CLP(Command Line Processor)允许用户动态 执行SQL语句和DB2命令 对本地和远程数据库服务器进行存取 允许用户开发基于ODBC或者JDBC的应用程序对数据库进行存 取
12/13
DB2连接器
提供对DRDA Requester的支持。
DB2 概述
Hale Waihona Puke 2/13DB2 UDB产品系列概述
DB2 UDB产品家族 UDB产品组件及其功能
3/13
UDB( DataBase) DB2 UDB(Universal DataBase)概述
DB2通用数据库是IBM的关系型数据库管理系统 关系型数据库管理系统,目前比 关系型数据库管理系统 较新的版本是9.5版本,它提供了对Windows、OS/2、AIX、 HP-UX、Solaris、UNIX等多种操作系统的支持。 根据不同用户群体的要求,DB2又向用户提供了企业版、 企业扩展版、工作组版、个人版、卫星版、微型版等多 种不同级别的产品。 DB2的历史:1983年发行的第一版是针对MVS系统的。1996 年的V5。1999年支持LINUX系统。2004年出版V8。2006年 V9
10/13
SDK客户端 SDK客户端
专门为应用程序开发人员提供的,包含了开发数据库应用程 序所需要的各种组件,包括Run-Time Client、预编译器、包 含文件、库函数、样例程序和帮助文档等。SDK客户端包含在 每张DB2服务器软件光盘中,可单独安装。
11/13
管理客户端
管理客户端的管理工具,它包含了一些图形化工具,用户可 以方便地通过这些工具对数据库服务器进行远程管理。