DBLINK

1.DBLINK 的定义

当我们要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中就必须

要创建远程数据库的DBLINK,通过DBLINK 本地数据库可以像访问本地数据库一样

访问远程数据库表中的数据。

2.创建 DBLINK 的语法

2.1定义 DBLINK 类型

EXEC master.dbo.sp_addlinkedserver

@server = '远程 IP 地址',

@srvproduct='DBLINK 类型(默认 SQL Server)'

2.2定义 DBLINK 连接属性

EXEC master.dbo.sp_addlinkedsrvlogin

@rmtsrvname='远程 IP 地址',

@useself='False',

@locallogin=NULL,

@rmtuser='远程数据库用户名',

@rmtpassword='远程数据库密码'

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

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_addlinkedsrvlogin

@rmtsrvname='192.168.0.39',

@useself='False',

@locallogin=NULL,

@rmtuser='sa',

@rmtpassword='!QAZ1234'

Go

执行完后我们会看到在 SSMS 的服务器对象下面有一个创建好的 DBLINK 连接,如下图:

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.39].SQL_Road.dbo.Orders o ON c.客户 ID=o.客户 ID

这样我们就将本来隔绝的两个表通过 DBLINK 关联上了。

5.删除 DBLINK

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

EXEC master.dbo.sp_dropserver

@server='192.169.0.39',

@droplogins='droplogins'

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

6.批注

DBLINK 是我们日常查询管理经常要使用到的一个利器,可以很方便的将原本隔开

的两个数据库建立起连接。为我们跨库查询提供一个非常便捷的方法。

你可能感兴趣的:(DBLINK)