源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

跨数据库实现数据交流

  • 时间:2022-03-30 05:08 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:跨数据库实现数据交流
通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。 [b]一、同SQL SERVER[/b] 这个最简单。直接在表名前加上"[数据库名]."就可以了。 例:
SELECT * FROM [DestinationDBName].dbo.DestinationTableName
[b]二、跨SQL SERVER[/b]  主要介绍两种方法: [b](一)通过链接服务器[/b] 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'
[b](二)使用OPENDATASOURCE/OPENROWSET连接远程服务器[/b]
SELECT * FROM OPENDATASOURCE
('SQLOLEDB', --provider_name
'Data Source=DestinationServerIP;User ID=UserName;Password=Password' --provider_string(datasource;user_id;password)
).[DestinationDBAlias].dbo.DestinationTableName

SELECT * FROM OPENROWSET
('SQLOLEDB',--provider_name
'DestinationServerIP';'UserName';'Password',--provider_string(datasource;user_id;password)
'SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName')--query_string

函数OPENQUERY也能实现跨服务器访问数据,但它是基于已经建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。 以上就是跨数据库实现数据交流的方法,希望大家可以亲自动手操作一下。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部