DBLINK的定义
当我们要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中就必须要创建远程数据库的DBLINK,通过DBLINK本地数据库可以像访问本地数据库一样访问远程数据库表中的数据。
创建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连接。
创建DBLINK连接示例
本地数据库IP地址是192.169.0.35,已知局域网有一台IP地址为192.169.0.39的数据库服务器,其账户和密码分别是sa和!QAZ1234,那么我们应该这样创建DBLINK连接:
USE masterGOEXEC master.dbo.sp_addlinkedserver @server = '192.169.0.39', @srvproduct='SQL Server'EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname='192.169.0.39',@useself='False',@locallogin=NULL,@rmtuser='sa',@rmtpassword='!QAZ1234'Go
执行完后我们会看到在SSMS的服务器对象下面有一个创建好的DBLINK连接,如下图:
![9973c09493772b98eb071afc19eb8e91.png](https://img-blog.csdnimg.cn/img_convert/9973c09493772b98eb071afc19eb8e91.png)
DBLINK的作用
前面的定义已经说明,通过DBLINK本地数据库可以像访问本地数据库一样访问远程数据库表中的数据。
DBLINK示例
以本地Customers表和远程数据库192.169.0.39里SQL_Road数据库下的Orders表为例
![60969ede9cab51ba3de2a51f09a3cd0a.png](https://img-blog.csdnimg.cn/img_convert/60969ede9cab51ba3de2a51f09a3cd0a.png)
Customers表
![0f3613854468c83d3acc6c05342dcc17.png](https://img-blog.csdnimg.cn/img_convert/0f3613854468c83d3acc6c05342dcc17.png)
远程数据库中的Orders表
我们想用本地的Customers表关联远程数据库192.169.0.39里SQL_Road数据库下的Orders表里的数据,可以这样写SQL:
SELECT c.姓名,o.订单日期 FROM Customers cJOIN [192.169.0.38].SQL_Road.dbo.Orders o ON c.客户ID=o.客户ID
结果如下:
![47a76be112164ab59721d05447b5ef1e.png](https://img-blog.csdnimg.cn/img_convert/47a76be112164ab59721d05447b5ef1e.png)
这样我们就将本来隔绝的两个表通过DBLINK关联上了。
删除DBLINK
当我们不需要DBLINK的时候,可以通过以下方式进行删除
EXEC master.dbo.sp_dropserver @server='192.169.0.39', @droplogins='droplogins'
这样就将刚创建的DBLINK删除了。
批注
DBLINK是我们日常查询管理经常要使用到的一个利器,可以很方便的将原本隔开的两个数据库建立起连接。为我们跨库查询提供一个非常便捷的方法。