欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Excel数据导入到Sql server

程序员文章站 2022-04-15 09:14:37
问题:数据库内直接操作导致 错误 0xc020901c: 数据流任务 1: 源 - yndata1$.输出[Excel 源输出] 上的 源 - yndata1$.输出[Excel 源输出].列[indications] 出错。返回的列状态是:“文本被截断,或者一个或多个字符在目标代码页中没有匹配项。 ......

问题:数据库内直接操作导致

 

错误 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、启用 ad hoc distributed queries 服务器配置选项

 

sp_configure 'show advanced options', 1;
reconfigure;
go
sp_configure 'ad hoc distributed queries', 1;
reconfigure;
go

2、代码示例使用 openrowset,将 excel sheet1 工作表中的数据导入新的数据库表。

 

select * into devices
from openrowset('microsoft.ace.oledb.12.0',
'excel 12.0; database=c:\users\administrator\desktop\devices.xlsx', [sheet1$]);
go