有关DB2常用命令总结

豆豆网   技术应用频道   2008年08月27日  【字号: 收藏本文

内容摘要:DB2常用命令总结:相比图形界面而言,使用命令行的命令可以节省很多内存资源。但是写的时候语法需要熟悉。

  相比图形界面而言,使用命令行的命令可以节省很多内存资源。但是写的时候语法需要熟悉。

  db2start:启动当前的DB2数据库管理实例。

  db2stop:停止当前的数据库管理实例。

  注:启动和关闭的是数据库管理实例,而不是单个的数据库,而restart database:并不是重新启动数据库,是平衡非正常结束而不一致状态的数据库,结束后,连接仍然存在。

  db2look:能为表,索引,视图和诸如此类需要产生统计信息和数据定义语言(DDL)的对象产生需要的语句,以便重建数据库对象和/或更新统计信息。DB2CLP下直接db2look,可看到选项。 db2move:db2移动数据的一个工具,可以在两个不同的db2数据库间移动数据,这两个DB2数据库可以在不同的服务器上,尤其是大量数据的表需要转移的情况下,非常方便。 DB2CLP下直接db2move,可看到选项。

  以下命令在“db2=>;”下键入“? Command”可以看到使用。

  catalog:编目数据库或节点

  uncatalog:删除已经编目的数据库或节点

  这一对命令其实就实现了客户机配置辅助程序编目数据库的功能。

  update:功能是更新数据库/数据库管理器配置参数,

  更新命令行处理器设置和监控器的开关等。

  connect:连接到一个数据库。

  注:习惯显式的关闭连接。

  attach:建立一个到实例的连接,执行实例级别的管理。

  list:显示一些数据库对象或者设置的相关信息

  get:获取一些数据库参数的设置和状态

  runstats:运行统计,更新系统目录表中的信息。

  backup:备份数据库

  1、防止意外数据丢失或系统意外

  2、重定向恢复实现整个数据库的迁移

  3、AIX下的备份需要指定with n buffers 和 buffer size

  restore:还原数据库

  注:操作系统相同才可进行备份和恢复

  force application:强行关闭应用程序或者连接

  导入导出数据:

  DEL:界定的ASCII文件,行分隔符和列分隔符将数据分开。常用

  ASC:定长的ASCII文件,行按照行分割符分开,列定长。

  PC/IXF:只能用来在db2之间导数据,根据类型数字值被打包成十进制或者二进制,字符被保存为ASCII,只保存变量已经使用了的长度,文件中包括表的定义和表的数据。

  WSF:工作表方式导入导出,不建议使用。

  export:导出数据,支持IXF,DEL或WSF

  import:导入数据,可以向表或者视图中导入数据,支持上面提到的4中文件。

  注:当一个表中的主键被其他表引用为外键时,导入数据只能选APPEND,不能选替换。

  load:导入数据,功能和import基本相同。支持以上说的4种格式。Load最大的缺点是变化没有记录日志,不能前滚恢复。

  Load的工作步骤:

  1、载入阶段:

  把数据载入到表中

  收集并存储索引

  2、建立阶段

  建立载入阶段收集的索引

  3、删除阶段

  把违反唯一键或主键约束的记录放到例外表中

  删除违反主键和唯一键约束的记录

  注:自动生成列数据导入问题。

  Load完毕之后:

  Load程序可以将表或者表所在的表空间处于挂起状态。

  1、载入挂起:在载入阶段发生错误,表空间处于此状态

  解决方法:

  A:纠正错误后重新载入,将replace或者insert换成restart。将从失败处重新开始装载操作。

  B:如果前面调用用了replace,则再使用replace做load。

  C:用terminate选项终止load操作。

  D:DBA撤消并重新建立表空间

  E:从一个备份中恢复表空间(归档日志下才可以)。

  2、删除挂起:在删除阶段发生错误,将一直处于删除挂起状态。

  3、备份挂起:这种策略是强迫用户对目标表所在的数据库或者表空间做一个备份。如果load是使用了copy no选项,并且开启了归档日志,load完后将处于该状态。做一个备份就可以消除该状态。

  4、检查挂起的表:当表上存在主键和唯一键之外的约束时,load完后表将处于该状态。包括以下情况:

  外键约束—用来强制执行内容的完整性。

  检查约束—用户定义的约束,检查合法性。

  操作中引用了summary表,并且表设置的为refresh immediate。

  可以使用如下命令解除该状态:

  SET CONSTRAINTS FOR TABNAME IMMEDIATE CHECKED FOR EXCEPTION IN EXP_TABLE

  load和import的不同:

  1、load的目标表必须存在,而import不需要

  2、load并不创建索引,只是在原来索引的基础上追加数据

  3、最大区别在于性能区别,import每次插入一条,每行都要进行一次限制检查,日志用来记录变化,而load插入则快的多,每次读取数据构造页,然后直接输入到数据库。插入完页后,索引将重新建立,违反主键和唯一键限制的记录将被删除并保存到另一个扩展表中。

作者:vlife    责编:豆豆技术应用

正在加载评论...