您当前的位置: 首页 > 数据库教程 > Oracle教程 > DB2文件导入导出常见命令总结

DB2文件导入导出常见命令总结

作者:不详 来源:网络 发布时间: 2011-10-14 14:47 点击:
Db2的数据迁移,最常用的就是导入导出功能,而导入导出的命令貌似简单,实则内含玄机,千变万化,稍不留神,则错误百出,这儿就工作中常用到的命令,总结了一下,分享给大家!欢迎大家踊跃拍砖!J 当然在这以前,我觉得有必要提及一点关于导入导出基础的知识! DEL:界

DB2文件导入导出常见命令总结

  Db2的数据迁移,最常用的就是导入导出功能,而导入导出的命令貌似简单,实则内含玄机,千变万化,稍不留神,则错误百出,这儿就工作中常用到的命令,总结了一下,分享给大家!欢迎大家踊跃拍砖!J
  
  当然在这以前,我觉得有必要提及一点关于导入导出基础的知识!
  
  DEL:界定的ASCII文件,行分隔符和列分隔符将数据分开。
  
  ASC:定长的ASCII文件,行按照行分割符分开,列定长。
  
  PC/IXF:只能用来在db2之间导数据,根据类型数字值被打包成十进制或者二进制,字符被保存为ASCII,只保存变量已经使用了的长度,文件中包括表的定义和表的数据。
  
  WSF:工作表方式导入导出,这种格式的文件类型用的比较少。
  
  Db2中对不同的数据导入导出方式,支持不同的文件类型,这里个人觉得很有必要注意的。
  
  文件类型Import export load
  
  -------------------------------------------------------
  
  定界支持支持支持
  
  非定界支持不支持支持
  
  Ixf支持支持支持
  
  Wsf工作表支持支持不支持
  
  关于3种导入导出操作进行简单的介绍:
  
  export:导出数据,支持IXF,DEL或WSF
  
  import:导入数据,可以向表中导入数据,支持上面提到的4种文件类型。
  
  load:导入数据,功能和import基本相同。支持以上说的几种文件类型。
  
  关于Export
  
  这个其实比较简单,没啥好说的,一般命令:export to filename of filetype select x from xx where;就ok了,这里需要注意的是:
  
  1.关于不同字符集的导出
  
  MODIFIED BY CODEPAGE=
  
  Exprot to filename.del for del MODIFIED BY CODEPAGE=1386select…from…where…;
  
  这里,在数据从数据库倒出来的时候就会做一个数据库代码页的转换
  
  2.时间字段格式化的
  
  MODIFIED BY TIMESTAMPFORMAT="yyyy-mm-dd hh:mm:ss tt"
  
  例:Exprot to filename.del for del MODIFIED BY TIMESTAMPFORMAT="yyyy-mm-dd hh:mm:ss tt" select…from…where…;
  
  关于Import
  
  1.Import模式的介绍
  
  CREATE/INSERT/INSERT_UPDATE/REPLACE/REPLACE_CREATE
  
  CREATE:首先创建目标表和它的索引,然后将数据导入到新表中。该选项惟一支持的文件格式是PC/IXF。还可以指定新表所在表空间的名称
  
  INSERT:将导入的数据插入表中。目标表必须已经存在。
  
  INSERT_UPDATE:将数据插入表中,或者更新表中具有匹配主键的行。目标表必须已经存在,并且定义了一个主键。
  
  REPLACE:删除所有已有的数据,并将导入的数据插入到一个已有的目标表中。
  
  REPLACE_CREATE:如果目标表已经存在,则导入实用程序删除已有的数据,并插入新的数据,就像REPLACE选项那样。如果目标表还没有定义,那么首先创建这个表以及它的相关索引,然后再导入数据。正如您可能想像的那样,输入文件必须是PC/IXF格式的文件,因为那种格式包含对导出表的结构化描述。如果目标表是被一个外键引用的一个父表,那么就不能使用REPLACE_CREATE。
  
  2.批量提交
  
  COMMITCOUNT,保证insert的数据在COMMITCOUNT以后进行一次commit,这对于大数据量的导入文件来说是一个不错的方法,
  
  例:Import from filename of del COMMITCOUNT50000insert into tabname;
  
  3.批量插入
  
  MODIFIED BY COMPOUND把文件中的COMPOUND行记录作为一组一起导入,这个操作可以和上边的批量提交一起使用,比较理想。
  
  例:Import from filename of del MODIFIED BY COMPOUND=50insert into tabname;
  
  4.导入记录限制
  
  ROWCOUNT:只导入rowcount条数据,有时候,业务逻辑需要只导入部分数据,那么ROWCOUNT是一个不错的选择,只是在我的测试中ROWCOUNT一直没有起过作用,呵呵,谁熟悉这里,帮我完善下。
  
  例:Import from filename of del ROWCOUNT10000insert into tabname;
  
  5.导入起点
  
  RESTARTCOUNT:从导入文件的第RESTARTCOUNT条记录开始导入
  
  例:Import from filename of del RESTARTCOUNT55ROWCOUNT10000insert into tabname;--从55条开始,导入10000条数据
  
  6.有警告数据的条数限制
  
  WARNINGCOUNT:当导入的数据中,有警告或错误(例如类型不匹配,列不对应等造成的)并且条数超过WARNINGCOUNT是就会停止import。
  
  例:Import from filename of del WARNINGCOUNT10insert into tabname;
  
  7.禁止发出行警告
  
  MODIFIED BY NOROWWARNINGS
  
  例:Import from filename of del MODIFIED BY NOROWWARNINGS WARNINGCOUNT10insert into tabname;
  
  8.LOB文件
  
  LOBS FROM:指出LOB的路径
  
  例:Import from filename of del LOBS FROM‘/home’MODIFIED BY NOROWWARNINGS WARNINGCOUNT10insert into tabname;
  
  9.对于自增序列(GENERATED ALWAYS)
  
  建议不要对自增序列的表进行import操作,因为import对于自增序列,只有MODIFIED BY IDENTITYIGNORE和MODIFIED BY IDENTITYMISSING的2中操作,这2中操作都会改变自增序列的原值,这样如果导出表和表之间有基于自增序列的关联关系的话,就失去了数据本身的意义,所以建议尽量少用基于import的自增表的操作,那该怎么做?可以用load老代替import,我们下来在load的操作中会讲到!
  
  关于Load
  
  1.字符串间隔,列间隔,小数点表示
  
  CHARDEL/COLDEL/DECPT
  
  例:LOAD CLIENT FROM'F:s1.del' OF DEL MODIFIED BY CHARDEL(COLDEL=DECPT?INSERT INTO"DB2ADMIN"."ZXTABLES"
  
  2.数据库记录中存在换行符,导致数据无法装入的情况
  
  MODIFIED BY DELPRIORITYCHAR
  
  Db2默认load优先级策略为,record delimiter,character delimiter,column delimiter,这样record delimiter得优先级最高,所以原始文件如果有换行的话load就认为是新的record,如果用户在某些情况下行里面包含了换行符(比如论坛里面的一条帖子,不可能把换行符删掉的),就必须用delprioritychar改变默认的优先级别,确保""之间的数据不管有没有换行符都被认为是同一条记录
  
  例:LOAD CLIENT FROM'F:s1.del' OF DEL MODIFIED BY DELPRIORITYCHAR INSERT INTO DB2ADMIN.ZXTABLES
  
  3.load后表空间暂挂的处理
  
  Copy YES/NONRECOVERABLE
  
  对于DMS表空间,load默认为copy NO模式,此模式下,load完成后,表空间会处于暂挂状态,这时候只能查表中的数据,需要对表空间进行一次备份,才可以对表进行update、insert等操作,那么我们可以使用如上2个命令,对于Copy YES,load完成以后会自动进行一次备份操作;NONRECOVERABLE指出load不可恢复,此命令符不会产生表空间暂挂,也不会自动进行表空间备份,但是他有一个缺点就是,不能恢复,当数据库进行回滚的时候,不能还原,危险等级还是比较高一点,不过个人觉得也NONRECOVERABLE比较实用。
  
  例:LOAD CLIENT FROM'F:s1.del' OF DEL INSERT INTO DB2ADMIN.ZXTABLES NONRECOVERABLE
  
  LOAD CLIENT FROM'F:s1.del' OF DEL INSERT INTO DB2ADMIN.ZXTABLES COPY YES
  
  4.load IXF类型文件到多分区数据库
  
  partitioned db configmode load_only_verify_part part_file_location
  
  当数据在2个不同数量节点的数据库之间移动,如果还想使用load来进行IXF的数据装载就比较棘手了,当时查遍IBM的官方文档均无所获,正郁郁不安时,狼出现了,给支了一招,现分享给大家。

分享到:
本文"DB2文件导入导出常见命令总结"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4