主页 > 知识库 > 跨数据库实现数据交流

跨数据库实现数据交流

热门标签:AI电销 网站排名优化 呼叫中心市场需求 Linux服务器 服务外包 百度竞价排名 地方门户网站 铁路电话系统

通常情况下,我们的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.DestinationTableName

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

函数OPENQUERY也能实现跨服务器访问数据,但它是基于已经建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。

以上就是跨数据库实现数据交流的方法,希望大家可以亲自动手操作一下。

您可能感兴趣的文章:
  • Access的跨库查询 (图)
  • SQLServer 跨库查询实现方法
  • Oracle跨数据库查询并插入实现原理及代码
  • 深入SQL Server 跨数据库查询的详解
  • 解析MSSQL跨数据库查询的实现方法
  • php结合ACCESS的跨库查询功能

标签:兰州 湖南 崇左 衡水 黄山 湘潭 铜川 仙桃

巨人网络通讯声明:本文标题《跨数据库实现数据交流》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266