SQL中的Dblink你了解多少?

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

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连接:

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的作用

前面的定义已经说明,通过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

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

EXEC master.dbo.sp_dropserver
@server='192.169.0.39',
@droplogins='droplogins'

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

总结

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

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

2021-08-31 07:54:24

SQLDblink查询

2020-03-02 14:55:02

JavaBigDecimalAPI

2016-08-17 10:24:28

2021-08-11 08:44:25

云计算混合云云网协同

2023-02-24 14:46:32

Java线程池编程

2023-12-09 08:58:30

AndroidActivity启动模式

2015-11-09 10:44:37

DevOpsIT运维

2023-12-11 13:59:00

YieldPython生成器函数

2020-03-25 08:47:22

智能边缘边缘计算网络

2023-10-29 08:35:47

AndroidAOP编程

2023-10-25 08:17:06

Lite模式代理类

2021-06-06 18:22:04

PprofGopher逻辑

2012-12-27 10:58:24

KVMKVM概念

2023-05-05 08:41:16

SQL字符函数

2022-06-07 07:37:40

线程进程开发

2019-08-07 17:18:18

云计算云原生函数

2023-09-07 10:26:50

接口测试自动化测试

2022-02-08 12:06:12

云计算

2011-08-23 11:03:35

ATM

2025-01-16 10:41:40

点赞
收藏

51CTO技术栈公众号