datastage插入表时字符长度过大

在使用DATASTAGE+ORACLE把一个文本文件的数据加载到数据库的时候,发现丢了一条记录,查看了一下job log,说插入值对于列过大。

用排除法最后确定是IMA32F这一列的问题,在数据库中关于这一列的定义是char(50)

可是源文件在transformer中已经做了截取处理了啊,substrings(trim(IMA32F),1,50) 这样怎么还会差不进去了。

很郁闷,无奈使用@inrownum找到是第166行出错了。打开文本文件,定位到166行,找到此字段的对应长度为26位汉字,然后再找到截取后的,发现还是26位!!

咦,咋没截断呢?

原来DS中中文字符是作为一个字符长度来处理的,而oracle中却是占用2个字符长度的

这样26*2=52 已经超过了char(50),怪不得查不进去呢。。。。得意

原因查到,由于此字段只可能为中文,所以改为substrings(trim(IMA32F),1,25)

运行成功,搞定!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值