SQLServer 跨庫查詢實現方法

來源:互聯網
上載者:User

本文給出一條 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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.