本文給出一條 SQL 陳述式用於展示在同一名伺服器上,不同的資料庫間查詢,注意當前串連使用者要對兩個庫都有許可權
SQL Server 中 SQL 陳述式中對象的完整運算式是:
[DatabaseServer].[DatabaseName].[DatabaseSchema].[DatabaseObject]
本文給出一條 SQL 陳述式用於展示在同一名伺服器上,不同的資料庫間查詢,注意當前串連使用者要對兩個庫都有許可權。 複製代碼 代碼如下:select *
from CfteaDb1.dbo.CfteaTable1 inner join CfteaDb2.dbo.CfteaTable2
on CfteaDb1.dbo.CfteaTable1.Id=CfteaDb2.dbo.CfteaTable2.Id
以上在 SQL Server 2008 R2 的 Management Studio 中測試成功。
下面是一些補充資料
不使用連結的伺服器名,而提供特殊的串連資訊,並將其作為四部分對象名的一部分。
文法
OPENDATASOURCE ( provider_name, init_string )
參數
provider_name
註冊為用於訪問資料來源的 OLE DB 提供者的 PROGID 的名稱。provider_name 的資料類型為 char,沒有預設值。
init_string
連接字串,這些字串將要傳遞給目標提供者的 IDataInitialize 介面。提供者字串文法是以關鍵字值對為基礎的,這些關鍵字值對由分號隔開,例如:"keyword1=value; keyword2=value."
在 Microsoft Data Access SDK 中定義了基本文法。有關所支援的特定關鍵字值對的資訊,請參見提供者中的文檔。下表列出 init_string 參數中最常用的關鍵字。
| 關鍵字 |
OLE DB 屬性 |
有效值和描述 |
| 資料來源 |
DBPROP_INIT_DATASOURCE |
要串連的資料來源的名稱。不同的提供者用不同的方法對此進行解釋。對於 SQL Server OLE DB 提供者來說,這會指明伺服器的名稱。對於 Jet OLE DB 提供者來說,這會指明 .mdb 檔案或 .xls 檔案的完整路徑。 |
| 位置 |
DBPROP_INIT_LOCATION |
要串連的資料庫的位置。 |
| 擴充屬性 |
DBPROP_INIT_PROVIDERSTRING |
提供者特定的連接字串。 |
| 連線逾時 |
DBPROP_INIT_TIMEOUT |
逾時值,在該逾時值後,串連嘗試將失敗。 |
| 使用者識別碼 |
DBPROP_AUTH_USERID |
用於該串連的使用者識別碼。 |
| 密碼 |
DBPROP_AUTH_PASSWORD |
用於該串連的密碼。 |
| 目錄 |
DBPROP_INIT_CATALOG |
串連到資料來源時的初始或預設的目錄名稱。 |
注釋
OPENDATASOURCE 函數可以在能夠使用連結的伺服器名的相同 Transact-SQL 文法位置中使用。因此,就可以將 OPENDATASOURCE 用作四部分名稱的第一部分,該名稱指的是 SELECT、INSERT、UPDATE 或 DELETE 語句中的表或視圖的名稱;或者指的是 EXECUTE 語句中的遠端預存程序。當執行遠端預存程序時,OPENDATASOURCE 應該指的是另一個 SQL Server。OPENDATASOURCE 不接受參數變數。
與 OPENROWSET 函數類似,OPENDATASOURCE 應該只引用那些不經常訪問的 OLE DB 資料來源。對於訪問次數稍多的任何資料來源,請為它們定義連結的伺服器。無論 OPENDATASOURCE 還是 OPENROWSET 都不能提供連結的伺服器定義的全部功能,例如,安全管理以及查詢目錄資訊的能力。每次調用 OPENDATASOURCE 時,都必須提供所有的串連資訊(包括密碼)。
樣本
下面的樣本訪問來自某個表的資料,該表在 SQL Server 的另一個執行個體中。 複製代碼 代碼如下:SELECT *
FROM OPENDATASOURCE(
'SQLOLEDB',
'Data Source=ServerName;User ID=MyUID;Password=MyPass'
).Northwind.dbo.Categories
下面是個查詢的樣本,它通過用於 Jet 的 OLE DB 提供者查詢 Excel 試算表。 複製代碼 代碼如下:SELECT *
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions