在DB2数据库中,在导出DEL文件时,默认的字符分隔符是"、字段分隔符是, (逗号)。有一个需求是要为Oracle数据库提供数据,因此就想使用“|”作为数据的字段分隔符。在查看了export的使用说明后,发现export的file-mod模式中可以通过CHARDELx和COLDELx,分别设置字符分隔符和字段分隔符。
但是,当运行export to 'e:\test.txt' of del modified by chardel0x22 coldel0x7c select * from db2admin.test命令后,却提示SQL3017N错误,错误描述信息如下:
SQL3017N 定界符无效,或使用多次。
说明:
对于"定界"ASCII (DEL) 文件,发生以下两种错误之一:
* 对列定界符、字符串定界符或小数点字符指定的字符无效。
* 对于 SBCS 或 UTF-8 数据,定界符的有效范围是 0x00 - 0x7F(包括 0x00
和 0x7F 在内)。
* 对于 MBCS 数据,定界符的有效范围是 0x00 - 0x3F(包括 0x00 和 0x3F
在内)。
* 对于 EBCDIC MBCS 数据,定界符的有效范围是 0x00 - 0x3F(包括 0x00
和 0x3F 在内),但是,有一种例外情况就是,定界符不能为 SHIFT-OUT
(0x0E)或者 SHIFT-IN(0x0F)字符。
* 为多个前述项目指定了同一个字符。
无法处理该命令。
用户响应:
检查指定的定界符的有效性和唯一性。重新提交该命令,并指定有效的定界符覆
盖。
原来,导出文件的分隔符是和数据库的代码页有关联的,即在代码页为819的数据库下,可以使用任何的字符(ASCII码)作为数据的分隔符,但是代码页为1386的数据库只能使用ASCII码值在0x00 - 0x3F 范围内的字符。
比如:db2 "export to test2.txt of del modified by coldel0x7F codepage=1208 nochardel select * from test"
还有一个要注意的问题:db2只支持单字符的列分隔符(coldel)