35 DBLINK

35.1 DBLINK的定义

当我们要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中就必须要创建远程数据库的DBLINK,通过DBLINk本地数据库可以像访问本地数据库表中的数据。

 

35.2 创建DBLINK的语法

定义DBLINK类型:

EXEC master.dbo.sp_addlinkedserver
@server='远程IP地址',
@srvproduct='DBLINK类型(默认SQL Server)'

定义DBLINK连接属性:

EXEC master.dbo.sp_addlinkedsrvlogin
@rmtsrvname='远程IP地址',
@useself='False',
@locallogin=NULL,
@rmtuser='远程数据库用户名',
@rmtpassword='远程数据库密码'

以上两步要一起执行才能生成DBLINK连接。

 

35.3 创建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_addlinkedlogin
@rmtsrvname='192.168.0.39',
@useself='False',
@locallogin=NULL,
@rmtuser='sa',
@rmtpassword='!QAZ1234'
GO

执行完后会看到在SSMS的服务器对象下面有一个创建好的DBLINK连接。

 

35.4 DBLINK的作用

通过DBLINK本地数据库可以像访问本地数据库一样访问远程数据库中的数据。

DBLINK示例:

以本地Customers表和远程数据库192.168.0.39里的SQL_Road数据库下的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关联上了。

 

35.5 删除DBLINK

当我们不需要DBLINK的时候,可以通过以下方式进行删除:

EXEC mater.dbo.sp_dropserver
@server='192.169.0.39'
@droplogins='droplogins'

这样就将刚创建的DBLINK删除了。

 

35.6 批注

DBLINK是日常查询管理经常要使用的一个利器,可以很方便的将原本隔开的两个数据库建立起连接。为我们跨库查询提供一个非常便捷的方法。

posted @ 2021-07-15 17:14  赵Gary  阅读(81)  评论(0)    收藏  举报