SQL高级知识——DBLINK

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

USE master
GO
EXEC 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连接,如下图:

30.jpg

DBLINK的作用

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


DBLINK示例

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

31.jpg

                                        Customers表

32.jpg


远程数据库中的Orders表


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

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

结果如下:

33.jpg

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


删除DBLINK

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

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

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


批注

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

相关文章
|
5月前
|
SQL
SQL 的 AND、OR 和 NOT 运算符:条件筛选的高级用法
SQL的AND运算符用于根据多个条件筛选记录,确保所有条件都为TRUE才返回记录。下面是AND运算符的基本语法:
109 1
|
SQL 监控 关系型数据库
【MYSQL高级】Mysql找出执行慢的SQL【慢查询日志使用与分析】
【MYSQL高级】Mysql找出执行慢的SQL【慢查询日志使用与分析】
1106 0
|
SQL 存储 关系型数据库
【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
142 0
|
5月前
|
SQL 存储 数据可视化
10个高级的 SQL 查询技巧
10个高级的 SQL 查询技巧
|
3月前
|
SQL 数据处理 数据库
SQL SELECT语句的高级应用与技巧
SQL SELECT语句的高级应用与技巧
|
4月前
|
SQL 存储 Java
SQL数据库学习指南:从基础到高级
SQL数据库学习指南:从基础到高级
|
4月前
|
SQL XML 数据库
后端数据库开发高级之通过在xml文件中映射实现动态SQL
后端数据库开发高级之通过在xml文件中映射实现动态SQL
42 3
|
5月前
|
SQL Oracle 关系型数据库
整合Mybatis-Plus高级,Oracle 主键Sequence,Sql 注入器实现自定义全局操作
整合Mybatis-Plus高级,Oracle 主键Sequence,Sql 注入器实现自定义全局操作
132 0
|
3月前
|
SQL 存储 Java
SQL数据库学习指南:从基础到高级
SQL数据库学习指南:从基础到高级
|
4月前
|
SQL 数据处理 数据库
SQL SELECT语句的高级应用与技巧
SQL SELECT语句的高级应用与技巧