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'); 
相关推荐
数据知道1 分钟前
PostgreSQL 实战:数组的增删改查与索引优化详解
数据库·postgresql
OceanBase数据库官方博客10 分钟前
深度解读 OceanBase 多模一体化能力
数据库·ai·oceanbase·分布式数据库
会飞的灰大狼12 分钟前
MySQL增量备份实战指南
数据库·mysql
宸津-代码粉碎机21 分钟前
用MySQL玩转数据可视化
数据库·mysql·信息可视化
步步为营DotNet21 分钟前
深度探索.NET 中ILogger:构建稳健日志系统的核心组件
数据库·.net
砚边数影24 分钟前
线性回归原理(二):梯度下降算法,Java实现单变量/多变量拟合
java·数据库·算法·线性回归·kingbase·kingbasees·金仓数据库
licheng996729 分钟前
工具、测试与部署
jvm·数据库·python
红队it33 分钟前
【数据分析+机器学习】基于机器学习的招聘数据分析可视化预测推荐系统(完整系统源码+数据库+开发笔记+详细部署教程)✅
数据库·机器学习·数据分析
明洞日记38 分钟前
【软考每日一练020】深入解析事务(Transaction)与ACID特性的工程实现
数据库·oracle
洋不写bug1 小时前
数据库的约束和主键
数据库