操作系統Windows Server 2008 X64,數據庫SQL Server 2008 X64,Office 2007(好像只有32位),在存儲過程執行OpenDatasource導入Access數據的時候遇到問題了,Oledb 4.0已經不被支持,以下是遇到的若干錯誤提示:
因為 OLE DB 訪問接口 'Microsoft.Jet.OLEDB.4.0' 配置為在單線程單元模式下運行,所以該訪問接口無法用于分布式查詢。
無法創建鏈接服務器 "(null)" 的 OLE DB 訪問接口 "Microsoft.Ace.OLEDB.12.0" 的實例。
因為 OLE DB 訪問接口 'Microsoft.Ace.OLEDB.12.0' 配置為在單線程單元模式下運行,所以該訪問接口無法用于分布式查詢 。
解決方案是安裝Office 2010 64位版, 網上有很多下載,然后下載Microsoft Access Database Engine 2010 的X64版本,網上也有下載,兩者缺一不可。
然后改一下OpenDatasource參數,將 Microsoft.Jet.OLEDB.4.0 改為 Microsoft.ACE.OLEDB.12.0,大功告成。
貼上存儲過程部分代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
--開啟導入功能 exec sp_configure 'show advanced options' ,1 reconfigure exec sp_configure 'Ad Hoc Distributed Queries' ,1 reconfigure --允許在進程中使用ACE.OLEDB.12 EXEC master.dbo.sp_MSset_oledb_prop N 'Microsoft.ACE.OLEDB.12.0' , N 'AllowInProcess' , 1 --允許動態參數 EXEC master.dbo.sp_MSset_oledb_prop N 'Microsoft.ACE.OLEDB.12.0' , N 'DynamicParameters' , 1 --導入臨時表 exec ( 'insert into jihua(id,[批次號],Right(' '' + @filepath + '' ',charindex(' '\'' ,REVERSE( '' '+ @filepath +' '' ))-1),getdate() FROM OPENDATASOURCE ( '' Microsoft.ACE.OLEDB.12.0 '' , '' Data Source= '+@filepath+' ; User ID=Admin; Password = '' )...計劃匯總表 ') --注意這里,要先關閉外圍的設置,然后再關閉高級選項 exec sp_configure' Ad Hoc Distributed Queries ',0 reconfigure exec sp_configure' show advanced options ',0 reconfigure --關閉ACE.OLEDB.12的選項 EXEC master.dbo.sp_MSset_oledb_prop N' Microsoft.ACE.OLEDB.12.0 ', N' AllowInProcess ', 0 EXEC master.dbo.sp_MSset_oledb_prop N' Microsoft.ACE.OLEDB.12.0 ', N' DynamicParameters', 0 |
以上內容僅是我的個人見解,相信解決辦法不止以上所述,希望大家多多分享自己的意見,共同交流學習進步。希望本文關于SQL SERVER 2008 64位系統無法導入ACCESS/EXCEL的解決方案對大家有所幫助。