聊聊SQL中的Dblink

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

[[420561]]

本文转载自微信公众号「SQL数据库开发」,作者丶平凡世界。转载本文请联系SQL数据库开发公众号。

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.168.0.35,已知局域网有一台IP地址为192.169.0.39的数据库服务器,其账户和密码分别是sa和!QAZ1234,那么我们应该这样创建DBLINK连接:

  1. USE master 
  2. GO 
  3.  
  4. EXEC master.dbo.sp_addlinkedserver 
  5. @server = '192.168.0.39'
  6. @srvproduct='SQL Server' 
  7.  
  8. EXEC master.dbo.sp_addlinkedsrvlogin 
  9. @rmtsrvname='192.168.0.39'
  10. @useself='False'
  11. @locallogin=NULL
  12. @rmtuser='sa'
  13. @rmtpassword='!QAZ1234' 
  14. Go 

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

DBLINK的作用

前面的定义已经说明,通过DBLINK本地数据库可以像访问本地数据库一样访问远程数据库表中的数据。

DBLINK示例

以本地Customers表和远程数据库192.168.0.39里SQL_Road数据库下的Orders表为例:

Customers表

远程数据库中的Orders表

我们想用本地的Customers表关联远程数据库192.168.0.39里SQL_Road数据库下的Orders表里的数据,可以这样写SQL:

  1. SELECT c.姓名,o.订单日期 FROM Customers c 
  2. JOIN [192.168.0.38].SQL_Road.dbo.Orders o ON c.客户ID=o.客户ID 

结果如下:

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

删除DBLINK

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

  1. EXEC master.dbo.sp_dropserver  
  2. @server='192.169.0.39'
  3. @droplogins='droplogins' 

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

总结 

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

 

责任编辑:武晓燕 来源: SQL数据库开发
相关推荐

2023-05-06 08:53:13

2021-09-03 06:46:34

SQL分组集功能

2021-08-16 08:12:04

SQLMerge用法

2023-07-28 09:54:14

SQL数据Excel

2022-08-03 08:11:58

数据测试同类型

2021-11-09 06:55:03

SQLServer排序

2023-08-29 09:46:12

SQLCTE递归

2022-10-17 08:22:28

2023-10-26 08:38:43

SQL排名平分分区

2022-07-27 08:31:28

SQL开发控制

2023-06-05 08:36:04

SQL函数RANK()

2021-11-17 08:11:35

MySQL

2023-11-09 11:56:28

MySQL死锁

2024-04-26 00:00:00

Rust检查器代码

2021-11-10 18:52:42

SQL技巧优化

2021-03-08 00:11:02

Spring注解开发

2021-10-30 19:56:10

Flutter按钮 Buttons

2022-05-11 09:01:54

Swift类型系统幻象类型

2022-07-04 08:54:39

Swift处理器项目

2024-04-15 00:00:00

RabbitMQ死信队列消息
点赞
收藏

51CTO技术栈公众号