【轉載】sql server中分佈式 鏈接服務器和遠程登錄映射

由於業務邏輯的多樣性
經常得在sql server中查詢不同數據庫中數據
這就產生了分佈式查詢的需求

現我將開發中遇到的幾種查詢總結如下:


1.access版本

--建立連接服務器
EXEC sp_addlinkedserver
--要創建的鏈接服務器名稱 
''''ai'''',            
--產品名稱              
''''access'''',    
--OLE DB 字符
''''Microsoft.Jet.OLEDB.4.0'''', 
--數據源
--格式:
-- 盤符:/路徑/文件名
-- //網絡名/共享名/文件名  (網絡版本)
''''d:/testdb/db.mdb''''
GO


--創建鏈接服務器上遠程登錄之間的映射
--鏈接服務器默認設置爲用登陸的上下文進行
--現在我們修改爲連接鏈接服務器不需使用任何登錄或密碼
exec sp_addlinkedsrvlogin ''''ai'''',''''false''''
go


--查詢數據
select * from ai...mytable
go

 

2.excel版本

--建立連接服務器
EXEC sp_addlinkedserver
--要創建的鏈接服務器名稱 
''''ai_ex'''',            
--產品名稱              
''''ex'''',    
--OLE DB 字符
''''Microsoft.Jet.OLEDB.4.0'''', 
--數據源
--格式:
-- 盤符:/路徑/文件名
-- //網絡名/共享名/文件名  (網絡版本)
''''d:/testdb/mybook.xls'''' ,
null,
--OLE DB 提供程序特定的連接字符串
''''Excel 5.0''''
GO


----創建鏈接服務器上遠程登錄之間的映射
--鏈接服務器默認設置爲用登陸的上下文進行
--現在我們修改爲連接鏈接服務器不需使用任何登錄或密碼
exec sp_addlinkedsrvlogin ''''ai_ex'''',''''false''''
go


--查詢數據
select * from ai_ex...sheet3$
go


3.ms sql版本

--建立連接服務器
EXEC sp_addlinkedserver
--要創建的鏈接服務器名稱 
''''ai_mssql'''',            
--產品名稱              
''''ms'''',    
--OLE DB 字符
''''SQLOLEDB'''', 
--數據源
''''218.204.111.111,3342''''
GO


--創建鏈接服務器上遠程登錄之間的映射
EXEC sp_addlinkedsrvlogin
''''ai_mssql'''',
''''false'''',
NULL,
--遠程服務器的登陸用戶名
''''zhangzhe'''',
--遠程服務器的登陸密碼
''''fish2231''''
go


--查詢數據
select * from ai_mssql.pubs.dbo.jobs
go


--還有一個更簡單的辦法
--這種方式在鏈接服務器建立後,它是默認開放RPC的

--建立連接服務器
EXEC sp_addlinkedserver
--要創建的鏈接服務器名稱
--這裏就用數據源作名稱
''''218.204.111.111,3342'''',
''''SQL Server''''
GO


--創建鏈接服務器上遠程登錄之間的映射
EXEC sp_addlinkedsrvlogin
''''218.204.111.111,3342'''',
''''false'''',
NULL,
--遠程服務器的登陸用戶名
''''zhangzhe'''',
--遠程服務器的登陸密碼
''''fish2231''''
go


--查詢數據
select * from [218.204.253.131,3342].pubs.dbo.jobs
go

 

4.Oracle版本

--建立連接服務器
EXEC sp_addlinkedserver
--要創建的鏈接服務器名稱 
''''o'''',
--產品名稱              
''''Oracle'''',
--OLE DB 字符
''''MSDAORA'''',
--數據源
''''acc''''
GO


--創建鏈接服務器上遠程登錄之間的映射
EXEC sp_addlinkedsrvlogin
''''o'''',
''''false'''',
NULL,
--Oracle服務器的登陸用戶名
''''F02M185'''',
--Oracle服務器的登陸密碼
''''f02m185185''''
go

--查詢數據
--格式:LinkServer..Oracle用戶名.表名
--注意用大寫,因爲在Oracle的數據字典中爲大寫
select * from o..F02M185.AI
go 
 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章