跨数据库实现数据交流
数据库  /  管理员 发布于 6年前   140
通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。
一、同SQL SERVER
这个最简单。直接在表名前加上"[数据库名]."就可以了。
例:
SELECT * FROM [DestinationDBName].dbo.DestinationTableName
二、跨SQL SERVER
主要介绍两种方法:
(一)通过链接服务器
1.先执行系统存储过程 sp_addlinkedserver :
EXEC sp_addlinkedserver @server='DestinationDBAlias',--目标数据库的别名,在连接并登录后,就可以用它来访问数据@srvproduct='',@provider='SQLOLEDB',@datasrc='DestinationServerIP\ServerName'--通常用"IP\端口名"组成,如果服务器上只装了一个MSSQL SERVER,或者装了多个MS SQLSERVER,但要访问的是默认端口,就不用加端口名
2.再执行系统存储过程 sp_addlinkedsrvlogin:
EXEC sp_addlinkedsrvlogin @rmtsrvname='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致@useself='false',@locallogin=NULL,@rmtuser='UserName',@rmtpassword='Password'
3.现在,我们可以通过目标数据库别名访问数据:
例:
SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName
4.使用结束,不要忘了断开与目标数据库的连接:
EXEC sp_dropserver @server='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致@droplogins='droplogins'
(二)使用OPENDATASOURCE/OPENROWSET连接远程服务器
SELECT * FROM OPENDATASOURCE('SQLOLEDB', --provider_name'Data Source=DestinationServerIP;User ID=UserName;Password=Password' --provider_string(datasource;user_id;password)).[DestinationDBAlias].dbo.DestinationTableNameSELECT * FROM OPENROWSET('SQLOLEDB',--provider_name'DestinationServerIP';'UserName';'Password',--provider_string(datasource;user_id;password)'SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName')--query_string
函数OPENQUERY也能实现跨服务器访问数据,但它是基于已经建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。
以上就是跨数据库实现数据交流的方法,希望大家可以亲自动手操作一下。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号