免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6731 | 回复: 11
打印 上一主题 下一主题

DB2中的数据移动(一) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-11-02 21:21 |只看该作者 |倒序浏览


  1.                               DB2中的数据移动
  2.                               

  3. DB2中所谓的数据移动,包括:
  4. 1. 数据的导入(Import)
  5. 2. 数据的导出(Export)
  6. 3. 数据的装入(Load)

  7. 导入和装入都是利用DB2的相关命令把某种格式的文件中的数据保存到数据库中的表中
  8. 导出是指把DB2数据库的表中的数据保存到某种格式的文件当中去

  9. 数据移动的作用:

  10. 如果要在不同的数据库管理系统之间转移数据,数据移动通常是最实用的一种方法,因为任何一种数据库管理系统都支持常用的几种文件格式,通过这个通用的接口,就很容易实现不同系统间数据的转移。

  11. 这三个命令中,Export最简单,因为从表中向文件转移数据,通常不会出现错误,也不会有非法的数据。

  12. 在讲解命令之前,首先介绍一下文件的格式,用于DB2数据移动的文件格式有四种:
  13. 1. ASC——非定界ASCII文件,是一个ASCII字符流。数据流中的行由行定界符分隔,而行中的每一列则通过起始和结束位置来定义。例如:

  14. 10   Head Office     160   Corporate   New York
  15. 15   New England  50     Eastern       Boston
  16. 20   Mid Atlantic     10     Eastern       Washington
  17. 38   South Atlantic 30     Eastern       Atlanta
  18. 42   Great Lakes    100   Midwest      Chicago
  19. 51   Plains              140   Midwest      Dallas
  20. 66   Pacific              270   Western     San Francisco
  21. 84   Mountain         290   Western     Denver

  22. 2. DEL——定界ASCII文件,也是一个ASCII字符流。数据流中的行由行定界符分隔,行中的列值由列定界符分隔。文件类型修饰符可用于修改这些定界符的默认值。例如:

  23. 10,"Head Office",160,"Corporate","New York"
  24. 15,"New England",50,"Eastern","Boston"
  25. 20,"Mid Atlantic",10,"Eastern","Washington"
  26. 38,"South Atlantic",30,"Eastern","Atlanta"
  27. 42,"Great Lakes",100,"Midwest","Chicago"
  28. 51,"Plains",140,"Midwest","Dallas"
  29. 66,"Pacific",270,"Western","San Francisco"
  30. 84,"Mountain",290,"Western","Denver"

  31. 3. WSF——(work sheet format)为工作表格式,用于与Lotus系列的软件进行数据交换。

  32. 4. PC/IXF——是集成交换格式(Integration Exchange Format,IXF)数据交换体系结构的改编版本,由一些列可变长度的记录构成,包括头记录、表记录、表中每列的列描述符记录以及表中每行的一条或多条数据记录。PC/IXF 文件记录由包含了字符数据的字段组成。

  33. 第一部分:数据的导出(Export)
  34. 例一:把Org表中的所有数据导出到文件C:\ORG.TXT中。
  35. Export to c:\org.txt of del select * from org

  36. 其中,of del表示导出到的文件的类型,在本例中导出到一个非定界文本文件中;后面的select * from org是一个SQL语句,该语句查询出来的结果就是要导出的数据。

  37. 例二:改变del格式文件的格式控制符
  38. export to c:\staff.txt of del modified by coldel$ chardel'' decplusblank select * from staff
  39. 在该例中,modified子句用于控制各种符号,coldel表示字段之间的间隔符,默认情况为逗号,现在改为$号;chardel表示字符串字段用什么符号引用,默认情况下为一对双引号括起来,现在改为用一对单引号括起来;decplusblank表示对于十进制数据类型,用空格代替最前面的加号,因为默认情况下会在十进制数据前面加上正负号的。

  40. 例三:以ASC格式将数据导出到文件
  41. Export命令是不支持ASC格式文件的,所以如果想导出ASC这样规整的格式,需要程序员自己进行转换操作,思路是将各种数据类型都转换成定长字符串,然后把各个要导出的字段合并成为一个字段。
  42. 例如创建如下结构的表n:
  43. create table n(a int,b date,c time,d varchar(5),e char(4),f double)
  44. 然后插入两条数据:
  45. insert into n values(15,'2004-10-21','23:12:23','abc','hh',35.2)
  46. insert into n values(5,'2004-1-21','3:12:23','bc','hhh',35.672)
  47. 要想把这两条数据以规整的格式导出到文件中,进行如下操作:
  48. export to c:\test.txt of del select char(a) || char(b) || char(c) || char(d,5) || e || char(f) as tmp from n
  49. 这样导出的结果与ASC格式的文件非常类似,只是每一行的前后多出了一对双引号,对此我们可以使用文本工具(如写字板、记事本等)把双引号删除掉,也可以置之不理,在以后导入的时候直接控制格式(忽略双引号)
  50. 在文件中的格式为:

  51. "15         2004-10-2123.12.23abc  hh  3.52E1                  "
  52. "5          2004-01-2103.12.23bc   hhh 3.5672E1                "

  53. 例四:大数据的导出
  54. export to d:\myfile.del of del lobs to d:\lob\ lobfile lobs modified by lobsinfile select * from emp_photo
  55. 该命令把emp_photo表的数据导出到d:\myfile.del文件中,其结果为:
  56. <pre>;
  57. "000130","bitmap","lobs.001.0.43690/"
  58. "000130","gif","lobs.001.43690.29540/"
  59. "000130","xwd","lobs.001.73230.45800/"
  60. "000140","bitmap","lobs.001.119030.71798/"
  61. "000140","gif","lobs.001.190828.29143/"
  62. "000140","xwd","lobs.001.219971.73908/"
  63. "000150","bitmap","lobs.001.293879.73438/"
  64. "000150","gif","lobs.001.367317.39795/"
  65. "000150","xwd","lobs.001.407112.75547/"
  66. "000190","bitmap","lobs.001.482659.63542/"
  67. "000190","gif","lobs.001.546201.36088/"
  68. "000190","xwd","lobs.001.582289.65650/"
  69. </pre>;
  70. 其中第三个字段是BLOB类型,在该文件中只保存了一个标志,相当于一个指针,真正的LOB数据保存在d:\lob目录下的lobs.001、lobs.002、......等一系列文件中。命令中lobs to 后面指定大对象数据保存在什么路径下(注意,该路径必须事先已经存在,否则会报错),lobfile 后面指定大对象数据保存在什么文件中,不要指定扩展名,DB2会根据数据量自动追加.001、.002等扩展名,同时不要忘记加上modified by lobsinfile子句。

  71. 例五:把导出信息保存在消息文件中。
  72. export to d:\awards.ixf of ixf messages d:\msgs.txt select * from staff where dept = 20
  73. 这个例子把staff表中dept=20的数据导出到d:\awards.ixf文件中,所有的导出信息都保存在d:\msgs.txt文件中(无论是成功、警告还是失败信息),这样,管理员可以通过观察信息文件找到问题所在。

  74. 例六:给导出数据列重命名。
  75. export to d:\awards.ixf of ixf method n(c1,c2,c3,c4,c5,c6,c7) messages d:\msgs.txt select * from staff where dept=20
  76. 在默认情况下,导出的每一列数据以表中对应的字段名自动命名,我们可以通过method n子句给每一列重新命名,需要注意的是,这个子句只在ixf和wsf格式文件中有效,在文本文件中不能使用。
复制代码

论坛徽章:
0
2 [报告]
发表于 2004-11-02 21:43 |只看该作者

DB2中的数据移动(一)

没有控制好格式,请斑竹删除,我做好格式后再重发,谢谢!

论坛徽章:
0
3 [报告]
发表于 2004-11-03 09:31 |只看该作者

DB2中的数据移动(一)

thanks for sharing your knowledge. If possible pls discuss about the load and import. Because I facing 1 problem for that. Import will be more saver, when import failed it won't lock the tablespace where using load if the process failed then it will lock the tablespace until we terminate it then it only back to normal state.

论坛徽章:
0
4 [报告]
发表于 2004-11-03 12:15 |只看该作者

DB2中的数据移动(一)

IMPORT和LOAD很快会做出来的,现在我不知道怎么控制显示的格式,在文本文件中是非常规整的格式,类似一张没有边界的表格,但是发表出来就会自动去掉字符串之间的空格,我知道这是浏览器的功能。

我试着在前后加上<pre>;和</pre>;,无效

又试着用nbsp;代替空格,也无效

应该怎么办呢?

论坛徽章:
0
5 [报告]
发表于 2004-11-05 09:39 |只看该作者

DB2中的数据移动(一)

没有人知道怎么控制格式吗?

实在不行的话,只好辛苦大家,把我的帖子复制到记事本中,然后用空格替换nbsp;,就可以看到规整的格式了。

论坛徽章:
0
6 [报告]
发表于 2004-11-18 13:45 |只看该作者

DB2中的数据移动(一)

擅自给你编辑了一下,您看行不行!

论坛徽章:
0
7 [报告]
发表于 2004-11-18 16:39 |只看该作者

DB2中的数据移动(一)

how u do that?

论坛徽章:
0
8 [报告]
发表于 2004-11-19 15:18 |只看该作者

DB2中的数据移动(一)

辛苦斑竹了。格式调整的不错,可是难道非得斑竹才能做吗?我自己应该怎么控制啊?

论坛徽章:
0
9 [报告]
发表于 2004-11-20 04:14 |只看该作者

DB2中的数据移动(一)

没怎么调整啊,只是把nbsp;替换掉再用Code引用罢了,这样格式会好点!

论坛徽章:
3
数据库技术版块每日发帖之星
日期:2016-03-17 06:20:00IT运维版块每日发帖之星
日期:2016-03-19 06:20:00数据库技术版块每日发帖之星
日期:2016-03-19 06:20:00
10 [报告]
发表于 2005-03-16 14:05 |只看该作者

DB2中的数据移动(一)

请问load和import哪个效率更高一些?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP