SQL高级知识:dblink

共 2718字,需浏览 6分钟

 ·

2024-05-22 16:00




点击关注公众号,SQL干货及时获取



后台回复:1024,获取海量学习资源


SQL刷题专栏





SQL145题系列




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连接,如下图:





DBLINK的作用


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


DBLINK示例


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





Customers





远程数据库中的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

结果如下:





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


删除DBLINK


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


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

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















最后给大家分享我写的SQL两件套:《SQL基础知识第二版》《SQL高级知识第二版》的PDF电子版。里面有各个语法的解释、大量的实例讲解和批注等等,非常通俗易懂,方便大家跟着一起来实操。




有需要的读者可以下载学习,在下面的公众号「数据前线」(非本号)后台回复关键字:SQL,就行



数据前线








——End——




后台回复关键字:1024,获取一份精心整理的技术干货


后台回复关键字:进群,带你进入高手如云的交流群。






推荐阅读









浏览 148
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报