copy导入ERROR:value too long for type……

错误描述

客户的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'); 
相关推荐
艾莉丝努力练剑5 分钟前
【QT】窗口
运维·网络·数据库·qt·计算机网络·microsoft
元拓数智17 分钟前
跨库NL2SQL可信落地的核心:用IntaLink破解数据关系“迷雾”
数据库·人工智能·ai·nlp·agent·llama
worilb22 分钟前
Spring Cloud 学习与实践(6):Nacos 配置中心
数据库·学习·spring cloud
lld95102723 分钟前
(三)本地策略框架
java·服务器·数据库
scan72425 分钟前
根据context={“query_type“: “vip“} 进行选择
数据库
Solis程序员29 分钟前
亿级流量下的 Redis 计数系统设计:位图事实 + 事件聚合 + SDS 汇总
数据库·redis·缓存
专注VB编程开发20年31 分钟前
C#,VB.NET 生成debug日志文件
服务器·数据库·c#
basketball61634 分钟前
Redis基础:4. 事务
数据库·redis·缓存
zzz_236836 分钟前
【Redis】缓存策略与三大经典问题
数据库·redis·缓存
菠萝猫yena1 小时前
【数据库软件】beekeeper-studio安装方式(Mac)
数据库