程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> Execl數據如何導入SQL Server 2005

Execl數據如何導入SQL Server 2005

編輯:關於SqlServer
在執行插入語句前,需要做下面幾步操作:

  1、從開始菜單進入到 配置工具 > SQL Server 2005 外圍應用配置器 > 服務和連接的外圍配置器 > Datebase Engine > 服務,然後重啟sqlserver服務。(在數據庫非正常關閉之後,可能會出現,“沒法初始化數據源的錯誤”,此時重啟一下sqlserver服務就可以了)

  2、然後運行 regedit 進入注冊表編輯器 HKEY_LOCAL_MacHINE\SOFTWARE\Microsoft\Microsoft SQL Server\MSSQL.1\Providers\Microsoft.Jet.OLEDB.4.0 新建DWord (64位值)名為DisallowAdhocAccess 值為0.

  3、注意:
  3.1、把需要導入的Execl文件關閉;
  3.2、配置工具 > SQL Server 外圍配置管理器 > 功能的外圍應用配置器 > Database Engine > 即席遠程查詢 > 啟用OPENROWSET 和 OPENDATASOURCE 支持 (勾選上)

  3、在執行插入語句前,必須先打開這個組件服務:

exec sp_configure 'show advanced options',1  
reconfigure  
exec sp_configure 'Ad Hoc Distributed QuerIEs',1  
reconfigure  

  注意:在每次用完之後,記得把它關閉。

exec sp_configure 'Ad Hoc Distributed QuerIEs',0  
reconfigure  
exec sp_configure 'show advanced options',0  
reconfigure

   4、插入語句:


select * into y from OpenDataSource('Microsoft.Jet.OLEDB.4.0','Data Source="G:\1.xls";Extended propertIEs= "Excel 8.0;HDR=YES;IMEX=1"')...[Sheet1$] insert into x select * from   OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel 8.0;HDR=YES;DATABASE=G:\1.xls',Sheet1$);

   <補充>

  參數HDR的值:

  HDR=Yes,這代表第一行是標題,不做為數據使用,如果用HDR=NO,則表示第一行不是標題,做為數據來使用。系統默認的是YES

  參數Excel 8.0

  對於Excel 97以上版本都用Excel 8.0

  IMEX ( IMport EXport mode )設置

  IMEX 有三種模式,各自引起的讀寫行為也不同,容後再述:  0 is Export mode

  1 is Import mode

  2 is Linked mode (full update capabilitIEs)

  我這裡特別要說明的就是 IMEX 參數了,因為不同的模式代表著不同的讀寫行為:

  當 IMEX=0 時為“匯出模式”,這個模式開啟的 Excel 檔案只能用來做“寫入”用途。

  當 IMEX=1 時為“匯入模式”,這個模式開啟的 Excel 檔案只能用來做“讀取”用途。

  當 IMEX=2 時為“連結模式”,這個模式開啟的 Excel 檔案可同時支援“讀取”與“寫入”用途。

  意義如下:

  0 ---輸出模式;

  1---輸入模式;

  2----鏈接模式(完全更新能力)

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved