sql server中分散式查詢隨筆

來源:互聯網
上載者:User
由於商務邏輯的多樣性
經常得在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

希望上面提到的知識對你有所提示
當然歡迎交流和指正

author:aierong
blog:http://www.cnblogs.com/aierong
email:aierong@126.com

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.