错误描述
客户的gaussdb数据库,由于权限有限。只有tdss客户端工具和gsql工具。现在是需要将一个较大的表,移到其他database的schema下。
使用以下方法,对于较小的表都成功了
#导入t1
copy t1 from '/data/input/t1.txt' delimiter '^';
#导出t1
copy t1 to '/data/input/t1_output.txt' delimiter '^';
然后在处理一张2000w行的大表时。导出成功,导入时报错ERROR:value too long for type......
分析尝试
1、尝试修改了较短的列,然后发现有多个列要改长度。最终确定是列错位,列顺序偏移了一位
2、尝试换过其他的分隔符(空格),仍然报错,且报错行数一致
3、尝试切分文件,报错行会发生变化,但是原因一样,出现错位
4、删除报错的行,发现报错行减少1,应该不是数据的问题
解决办法
使用binary的格式导出导入解决(more大概看了下binary的格式,发现其组织形式是列的)
copy t1 to '/data/input/t1_output.bin' with(format 'BINARY');
copy t1 from '/data/input/t1_output.bin' with(format 'BINARY');