跨數(shù)據(jù)庫實現(xiàn)數(shù)據(jù)交流
通常情況下,我們的CRUD操作都在單一數(shù)據(jù)庫中進行。但是,也可能會遇到需要進行跨數(shù)據(jù)交流的情況。對此,我以跨數(shù)據(jù)庫進行表的訪問為例,稍微總結(jié)了下。
一、同SQL SERVER
這個最簡單。直接在表名前加上"[數(shù)據(jù)庫名]."就可以了。
例:
SELECT * FROM [DestinationDBName].dbo.DestinationTableName
二、跨SQL SERVER
主要介紹兩種方法:
(一)通過鏈接服務(wù)器
1.先執(zhí)行系統(tǒng)存儲過程 sp_addlinkedserver :
EXEC sp_addlinkedserver @server='DestinationDBAlias',--目標數(shù)據(jù)庫的別名,在連接并登錄后,就可以用它來訪問數(shù)據(jù) @srvproduct='', @provider='SQLOLEDB', @datasrc='DestinationServerIP\ServerName'--通常用"IP\端口名"組成,如果服務(wù)器上只裝了一個MSSQL SERVER,或者裝了多個MS SQLSERVER,但要訪問的是默認端口,就不用加端口名
2.再執(zhí)行系統(tǒng)存儲過程 sp_addlinkedsrvlogin:
EXEC sp_addlinkedsrvlogin @rmtsrvname='DestinationDBAlias',--注意這里的名字應(yīng)與第一步sp_addlinkedserver中@server值一致 @useself='false', @locallogin=NULL, @rmtuser='UserName', @rmtpassword='Password'
3.現(xiàn)在,我們可以通過目標數(shù)據(jù)庫別名訪問數(shù)據(jù):
例:
SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName
4.使用結(jié)束,不要忘了斷開與目標數(shù)據(jù)庫的連接:
EXEC sp_dropserver @server='DestinationDBAlias',--注意這里的名字應(yīng)與第一步sp_addlinkedserver中@server值一致 @droplogins='droplogins'
(二)使用OPENDATASOURCE/OPENROWSET連接遠程服務(wù)器
SELECT * FROM OPENDATASOURCE ('SQLOLEDB', --provider_name 'Data Source=DestinationServerIP;User ID=UserName;Password=Password' --provider_string(datasource;user_id;password) ).[DestinationDBAlias].dbo.DestinationTableName SELECT * FROM OPENROWSET ('SQLOLEDB',--provider_name 'DestinationServerIP';'UserName';'Password',--provider_string(datasource;user_id;password) 'SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName')--query_string
函數(shù)OPENQUERY也能實現(xiàn)跨服務(wù)器訪問數(shù)據(jù),但它是基于已經(jīng)建立鏈接服務(wù)器的基礎(chǔ)上來操作的,應(yīng)屬第一種方法,在此不再贅述。
以上就是跨數(shù)據(jù)庫實現(xiàn)數(shù)據(jù)交流的方法,希望大家可以親自動手操作一下。
相關(guān)文章
SQL Server Alwayson添加監(jiān)聽器失敗的解決方法
這篇文章主要為大家詳細介紹了SQL Server Alwayson添加監(jiān)聽器失敗的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07SQLSERVER?出現(xiàn)死鎖查找方法和解決辦法(推薦)
這篇文章主要介紹了SQLSERVER?出現(xiàn)死鎖查找方法和解決辦法(推薦),文中講解了查詢死鎖語句,殺死死鎖的解決方法,需要的朋友可以參考下2024-02-02SQL事務(wù)用法begin tran,commit tran和rollback tran的用法
Sql Server 2005/2008中提供了begin tran,commit tran和rollback tran來使用事務(wù)。begin tran表示開始事務(wù), commit tran表示提交事務(wù),rollback tran表示回滾事物2011-12-12SQL Server恢復(fù)模型之批量日志恢復(fù)模式
這篇文章主要介紹了SQL Server恢復(fù)模型之批量日志恢復(fù)模式,需要的朋友可以參考下2014-10-10