从Excel表格导入Mssql 2008,字段长度问题

将表格的数据导入到数据库临时表时,出现了以下错误信息:

  • 正在执行 (错误) 消息 错误 0xc020901c: 数据流任务 1: 输出“Excel 源输出”(9) 上的 输出列“产品种类”(30) 出错。返回的列状态是:“文本被截断,或者一个或多个字符在目标代码页中没有匹配项。”。 (SQL Server 导入和导出向导)

错误 0xc020902a: 数据流任务 1: “输出列“产品种类”(30)”由于发生截断而失败,而且针对“输出列“产品种类”(30)”的截断行处理设置指定截断时出错。在指定组件的指定对象上出现截断错误。
(SQL Server 导入和导出向导)

错误 0xc0047038: 数据流任务 1: SSIS 错误代码 DTS_E_PRIMEOUTPUTFAILED。组件“源 - Customer0815$”(1) 的 PrimeOutput 方法返回了错误代码 0xC020902A。管道引擎调用 PrimeOutput() 时该组件返回了一个失败代码。虽然该失败代码只与该组件有关,但这个错误是致命的,管道已停止执行。可能在此之前已经发出错误消息,提供了有关失败的详细信息。
(SQL Server 导入和导出向导)

求解决~~

2个回答

已经很明显告诉你Excel中的长度大于了数据库中表字段的长度了。
处理方法:
在Excel里面做一个公式列用来判断“产品种类”这列大于数据库字段最大长度的公式。
例如:产品种类为第G列,数据库对应这列的最大长度为200,写一个公式 Len($G1)>200,这样看这一行有没有为True的项

yangjp8023
龔城師 我的问题已经解决了,虽然不是这个问题,但是还是采纳一下
4 年多之前 回复

增加列的长度,或者减少excel列内容的长度

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问