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)

运行成功,搞定!

你可能感兴趣的:(数据库,oracle,DATASTAGE)