当我们要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中就必须要创建远程数据库的DBLINK,通过DBLINK本地数据库可以像访问本地数据库一样访问远程数据库表中的数据。
定义DBLINK连接属性
以上两步要一起执行才能生成DBLINK连接。
本地数据库IP地址是192.168.0.35,已知局域网有一台IP地址为192.169.0.39的数据库服务器,其账户和密码分别是sa和!QAZ1234,那么我们应该这样创建DBLINK连接:
USE master
GO
EXEC master.dbo.sp_addlinkedserver
@server = '192.168.0.39',
@srvproduct='SQL Server'
EXEC master.dbo.sp_addlinkedsrvlogin
@rmtsrvname='192.168.0.39',
@useself='False',
@locallogin=NULL,
@rmtuser='sa',
@rmtpassword='!QAZ1234'
Go
执行完后我们会看到在SSMS的服务器对象下面有一个创建好的DBLINK连接,如下图:
前面的定义已经说明,通过DBLINK本地数据库可以像访问本地数据库一样访问远程数据库表中的数据。
以本地Customers表和远程数据库192.168.0.39里SQL_Road数据库下的Orders表为例
Customers表
远程数据库中的Orders表
我们想用本地的Customers表关联远程数据库192.168.0.39里SQL_Road数据库下的Orders表里的数据,可以这样写SQL:
SELECT c.姓名,o.订单日期 FROM Customers c
JOIN [192.168.0.38].SQL_Road.dbo.Orders o ON c.客户ID=o.客户ID
结果如下:
这样我们就将本来隔绝的两个表通过DBLINK关联上了。
当我们不需要DBLINK的时候,可以通过以下方式进行删除
EXEC master.dbo.sp_dropserver
@server='192.169.0.39',
@droplogins='droplogins'
这样就将刚创建的DBLINK删除了。
DBLINK是我们日常查询管理经常要使用到的一个利器,可以很方便的将原本隔开的两个数据库建立起连接。为我们跨库查询提供一个非常便捷的方法。
网站名称:SQL中的Dblink你了解多少?
URL标题:http://www.mswzjz.cn/qtweb/news42/381742.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能