Excel大数据字段导入SQLserver时报截断错误

1 篇文章 0 订阅
1 篇文章 0 订阅

一、问题描述:


在导入时报错如下:

错误 0xc020901c: 数据流任务 1: 源 - yndata1$.输出[Excel 源输出] 上的 源 - yndata1$.输出[Excel 源输出].列[indications] 出错。返回的列状态是:“文本被截断,或者一个或多个字符在目标代码页中没有匹配项。”。
 (SQL Server 导入和导出向导)
错误 0xc020902a: 数据流任务 1: “源 - yndata1$.输出[Excel 源输出].列[indications]”由于发生截断而失败,而且针对“源 - yndata1$.输出[Excel 源输出].列[indications]”的截断行处理设置指定截断时出错。在指定组件的指定对象上出现截断错误。
 (SQL Server 导入和导出向导)
错误 0xc0047038: 数据流任务 1: SSIS 错误代码 DTS_E_PRIMEOUTPUTFAILED。源 - yndata1$ 的 PrimeOutput 方法返回了错误代码 0xC020902A。管道引擎调用 PrimeOutput() 时该组件返回了一个失败代码。虽然该失败代码只与该组件有关,但这个错误是致命的,管道已停止执行。可能在此之前已经发出错误消息,提供了有关失败的详细信息。
 (SQL Server 导入和导出向导)



二、解决方案:
1、这里面有两个字段数据量可能比较大,indications和remarks。创建用nvarchar(max)。

CREATE TABLE [dbo].[yndata] (
[itemno] nvarchar(1000),
[itemname] nvarchar(4000),
[remarks] nvarchar(4000),
[prdclassN] nvarchar(4000),
[prdclassNVI] nvarchar(4000),
[itemtypeN] nvarchar(4000),
[itemtypeNVI] nvarchar(4000),
[indications] nvarchar(4000)
)

alter table [yndata] alter column [indications] nvarchar(max);
alter table [yndata] alter column [remarks] nvarchar(max);
---------------------------------------------


2、只有nvarchar(max)还不能解决问题。似乎在读取excel时,会根据第一行的数据量大小确定列的类型和长度。因此,如果第一行各列的数据都比较小,而后面某行某列的数据比较大时,会报截断错误。因此,需要在伪造第一行数据,给各列赋上很大的值。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值