sql server2017从MySQL导入数据到SQL Server时报错:截断行处理设置指定截断时出错解决方案

今天晚上在跑SQL Server代理作业时报错:

错误: 0xC020902A,位于 credit_ious_instalment, 源 - 查询 [2]: “源 - 查询”由于发生截断而失败,而且针对“源 - 查询.输出[ADO NET 源输出].列[ious_no]”的截断行处理设置指定截断时出错。在指定组件的指定对象上出现截断错误。
错误: 0xC02090F5,位于 credit_ious_instalment, 源 - 查询 [2]: 源 - 查询 无法处理这些数据。管道组件已从方法调用返回了 HRESULT 错误代码 0xC020902A。

在网上查下报错原因,基本上都是说源数据表中的字段长度与目标数据表的字段长度不一样导致,我在MySQL数据库中找到报错的表,发现字段ious_no是varchar(22),SQL Server中表的字段ious_no是[nvarchar](22),字段类型和长度没问题呀。。。
在这里插入图片描述
在这里插入图片描述

各种尝试测试,最后发现在SSIS包输入源–>右击–>显示高级编辑器中–>ADN NET输出–>外部列和输出列都为20导致,改成22就OK了
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

总结:出现这种报错是因为字段长度小了导致,排除方法:

  1. 先查源表中该字段的类型和长度,目标表中的类型是否和源表字段类型一致、长度是否大于或等于源表字段
  2. 如果符合上面的条件,就要看SSIS包源的高级设置中外部列和输出列的字段长度是否大于或等于源数据表中的字段长度
  3. 在数据库中字符串建议char、varchar、nchar、nvarchar
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值