SQLLDR错误Field in data file exceeds maximum length

本文介绍了解决从CSV文件导入数据到Oracle数据库时遇到的字段类型不匹配问题。具体来说,是关于如何处理因控制文件(CTL)中字段类型默认设置与表中实际字段类型(特别是VARCHAR与CHAR的区别)不一致导致的数据加载失败的情况。

创建表

create table objects(

owner varchar2(30),

object_name varchar2(50),

object_id number,

status varchar2(10),

created date);

控制文件

LOAD DATA
INFILE ldr_object.csv
TRUNCATE INTO TABLE OBJECTS
FIELDS TERMINATED BY "," OPTIONALLY ENCLOSED BY '"'
(owner,
object_name,
object_id,
created date 'yyyy-mm-dd hh24:mi:ss',
status )

加载以后提示 如标题所示错误

原来表中定义的字段 status 虽然是VARCHAR(10);

        但是用控制文件(CTL)中默认为是char类型。

        所以,当该列数据长度超过255(char类型长度)时会提示出错。

将数据文件和控制文件都改为 char类型即可

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值