由于業(yè)務(wù)邏輯的多樣性,經(jīng)常得在sql server中查詢不同數(shù)據(jù)庫中數(shù)據(jù),這就產(chǎn)生了分布式查詢的需求
現(xiàn)我將開發(fā)中遇到的幾種查詢總結(jié)如下:
1.access版本
--建立連接服務(wù)器
EXEC sp_addlinkedserver
--要?jiǎng)?chuàng)建的鏈接服務(wù)器名稱?
'ai',????????????
--產(chǎn)品名稱??????????????
'access',????
--OLE DB 字符
'Microsoft.Jet.OLEDB.4.0',?
--數(shù)據(jù)源
--格式:
-- 盤符:\路徑\文件名
-- \\網(wǎng)絡(luò)名\共享名\文件名? (網(wǎng)絡(luò)版本)
'd:\testdb\db.mdb'
GO
--創(chuàng)建鏈接服務(wù)器上遠(yuǎn)程登錄之間的映射
--鏈接服務(wù)器默認(rèn)設(shè)置為用登陸的上下文進(jìn)行
--現(xiàn)在我們修改為連接鏈接服務(wù)器不需使用任何登錄或密碼
exec sp_addlinkedsrvlogin 'ai','false'
go
--查詢數(shù)據(jù)
select * from ai...mytable
go
?
2.excel版本
--建立連接服務(wù)器
EXEC sp_addlinkedserver
--要?jiǎng)?chuàng)建的鏈接服務(wù)器名稱?
'ai_ex',????????????
--產(chǎn)品名稱??????????????
'ex',????
--OLE DB 字符
'Microsoft.Jet.OLEDB.4.0',?
--數(shù)據(jù)源
--格式:
-- 盤符:\路徑\文件名
-- \\網(wǎng)絡(luò)名\共享名\文件名? (網(wǎng)絡(luò)版本)
'd:\testdb\mybook.xls' ,
null,
--OLE DB 提供程序特定的連接字符串
'Excel 5.0'
GO
----創(chuàng)建鏈接服務(wù)器上遠(yuǎn)程登錄之間的映射
--鏈接服務(wù)器默認(rèn)設(shè)置為用登陸的上下文進(jìn)行
--現(xiàn)在我們修改為連接鏈接服務(wù)器不需使用任何登錄或密碼
exec sp_addlinkedsrvlogin 'ai_ex','false'
go
--查詢數(shù)據(jù)
select * from ai_ex...sheet3$
go
3.ms sql版本
--建立連接服務(wù)器
EXEC sp_addlinkedserver
--要?jiǎng)?chuàng)建的鏈接服務(wù)器名稱?
'ai_mssql',????????????
--產(chǎn)品名稱??????????????
'ms',????
--OLE DB 字符
'SQLOLEDB',?
--數(shù)據(jù)源
'218.204.111.111,3342'
GO
--創(chuàng)建鏈接服務(wù)器上遠(yuǎn)程登錄之間的映射
EXEC sp_addlinkedsrvlogin
'ai_mssql',
'false',
NULL,
--遠(yuǎn)程服務(wù)器的登陸用戶名
'zhangzhe',
--遠(yuǎn)程服務(wù)器的登陸密碼
'fish2231'
go
--查詢數(shù)據(jù)
select * from ai_mssql.pubs.dbo.jobs
go
--還有一個(gè)更簡單的辦法
--這種方式在鏈接服務(wù)器建立后,它是默認(rèn)開放RPC的
--建立連接服務(wù)器
EXEC sp_addlinkedserver
--要?jiǎng)?chuàng)建的鏈接服務(wù)器名稱
--這里就用數(shù)據(jù)源作名稱
'218.204.111.111,3342',
'SQL Server'
GO
--創(chuàng)建鏈接服務(wù)器上遠(yuǎn)程登錄之間的映射
EXEC sp_addlinkedsrvlogin
'218.204.111.111,3342',
'false',
NULL,
--遠(yuǎn)程服務(wù)器的登陸用戶名
'zhangzhe',
--遠(yuǎn)程服務(wù)器的登陸密碼
'fish2231'
go
--查詢數(shù)據(jù)
select * from [218.204.253.131,3342].pubs.dbo.jobs
go
?
4.Oracle版本
--建立連接服務(wù)器
EXEC sp_addlinkedserver
--要?jiǎng)?chuàng)建的鏈接服務(wù)器名稱?
'o',
--產(chǎn)品名稱??????????????
'Oracle',
--OLE DB 字符
'MSDAORA',
--數(shù)據(jù)源
'acc'
GO
--創(chuàng)建鏈接服務(wù)器上遠(yuǎn)程登錄之間的映射
EXEC sp_addlinkedsrvlogin
'o',
'false',
NULL,
--Oracle服務(wù)器的登陸用戶名
'F02M185',
--Oracle服務(wù)器的登陸密碼
'f02m185185'
go
--查詢數(shù)據(jù)
--格式:LinkServer..Oracle用戶名.表名
--注意用大寫,因?yàn)樵贠racle的數(shù)據(jù)字典中為大寫
select * from o..F02M185.AI
go
sql server中分布式查詢隨筆(鏈接服務(wù)器(sp_addlinkedserver)和遠(yuǎn)程登錄映射(sp_addlinkedsrvlogin)使用小總結(jié))
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
