sql server 中获取前一天日期_SQL高级知识——DBLINK
发布日期:2022-02-04 03:25:49 浏览次数:7 分类:技术文章

本文共 1384 字,大约阅读时间需要 4 分钟。

2e28a819bbca925626363cfcfc1f30aa.png

关注公众号: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.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连接,如下图:

25dbf4501cc69b9dd2ce140fda164488.png

DBLINK的作用

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

DBLINK示例

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

b41edda32eb3ade96ec27b203b6f6586.png
Customers表

b024a75fb3e0090ecc5cbc7f12dae37b.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

结果如下:

37b36b82263ea7e4ec18739e55fead9b.png

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

删除DBLINK

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

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

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

批注

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

欢迎关注我的公众号:【SQL数据库开发】

转载地址:https://blog.csdn.net/weixin_39626369/article/details/111091051 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:ab编程软件studio5000_AB PLC | STUDIO 5000仿真软件大合集
下一篇:sqlserver执行了drop table 恢复没有备份_又一程序员删库跑路被拘留?教你如何一键恢复!...

发表评论

最新留言

不错!
[***.144.177.141]2024年04月08日 20时06分33秒