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

猜你喜欢

转载自blog.csdn.net/lz6363/article/details/85010618
今日推荐