SELECT * FROM OPENDATASOURCE( 'SQLOLEDB','DataSource=192.168.1.113;User ID=sa;Password=123456').pubs.dbo.authors
SELECT * FROM OPENDATASOURCE(SQLOLEDB, Data Source=192.168.18.252;User ID=sa;Password=test).pubs.dbo.authors
這條語句的功能是查詢192.168.18.252這臺機器中SQL Server數據庫pubs中的authors表。從這條語句可以看出,OPENDATASOURCE有兩個參數,第一個參數是 provider_name,表示用于訪問數據源的 OLE DB 提供程序的 PROGID 的名稱。provider_name 的數據類型為 char,沒有默認值。第二個參數是連接字符串,根據OLE DB Provider不同而不同(如果不清楚自己所使用的OLE DB Provider的連接字符串,可以使用delphi、visual studio等開發工具中的ADO控件自動生成相應的連接字符串)。
SELECT * INTO access FROM OPENDATASOURCE( Microsoft.Jet.OLEDB.4.0, Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\data.mdb;Persist Security Info=False)...table1
或者使用OPENROWSET
SELECT * FROM OPENROWSET(Microsoft.Jet.OLEDB.4.0, c:\data.mdb;admin;,SELECT * FROM table1)
導出數據
INSERT INTO OPENDATASOURCE(Microsoft.Jet.OLEDB.4.0,Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\data.mdb;Persist Security Info=False)...table1 SELECT * FROM access
打開access數據庫的OLE DB Provider叫Microsoft.Jet.OLEDB.4.0,需要注意的是操作非SQL Server數據庫在OPENDATASOURCE(...)后面引用數據庫中的表時使用"...”,而不是“.”。
(3). SQL Server數據庫和文本文件之間的數據導入導出。 導入數據
SELECT * INTO text1 FROM OPENDATASOURCE(MICROSOFT.JET.OLEDB.4.0,Text;DATABASE=c:\)...[data#txt]
導出數據
INSERT INTO OPENDATASOURCE(MICROSOFT.JET.OLEDB.4.0,Text;DATABASE=c:\)...[data#txt] SELECT * FROM text1
或者使用OPENROWSET
INSERT INTO OPENROWSET(MICROSOFT.JET.OLEDB.4.0,Text;DATABASE=c:\, [data#txt]) SELECT * FROM text1
如果要插入部分字段,可使用
INSERT INTO OPENROWSET(MICROSOFT.JET.OLEDB.4.0,Text;DATABASE=c:\, SELECT aa FROM [data#txt]) SELECT aa FROM text1
INSERT INTO OPENDATASOURCE(MICROSOFT.JET.OLEDB.4.0,Excel 5.0;DATABASE=c:\book1.xls )...[Sheet1$] SELECT * FROM OPENROWSET(Microsoft.Jet.OLEDB.4.0, c:\data.mdb;admin;,SELECT * FROM table1)