跨数据库实现数据交流

这篇文章主要介绍了跨数据库实现数据交流的两种方式,一是通过链接服务器,二是使用OPENDATASOURCE/OPENROWSET连接远程服务器,需要的朋友可以参考下

通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。

一、同SQL SERVER

这个最简单。直接在表名前加上"[数据库名]."就可以了。

例:

?

1

SELECT * FROM [DestinationDBName].dbo.DestinationTableName

二、跨SQL SERVER

主要介绍两种方法:

(一)通过链接服务器

1.先执行系统存储过程 sp_addlinkedserver :

?

1

2

3

4

5

EXEC sp_addlinkedserver

@server='DestinationDBAlias',–目标数据库的别名,在连接并登录后,就可以用它来访问数据

@srvproduct='',

@provider='SQLOLEDB',

@datasrc='DestinationServerIP\\ServerName'–通常用"IP\\端口名"组成,如果服务器上只装了一个MSSQL SERVER,或者装了多个MS SQLSERVER,但要访问的是默认端口,就不用加端口名

2.再执行系统存储过程 sp_addlinkedsrvlogin:

?

1

2

3

4

5

6

EXEC sp_addlinkedsrvlogin

@rmtsrvname='DestinationDBAlias',–注意这里的名字应与第一步sp_addlinkedserver中@server值一致

@useself='false',

@locallogin=NULL,

@rmtuser='UserName',

@rmtpassword='Password'

3.现在,我们可以通过目标数据库别名访问数据:

例:

?

1

SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName

4.使用结束,不要忘了断开与目标数据库的连接:

?

1

2

3

EXEC sp_dropserver

@server='DestinationDBAlias',–注意这里的名字应与第一步sp_addlinkedserver中@server值一致

@droplogins='droplogins'

(二)使用OPENDATASOURCE/OPENROWSET连接远程服务器

?

1

2

3

4

5

6

7

8

9

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

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

版权声明:本文(即:原文链接:https://www.qin1qin.com/catagory/27402/)内容由互联网用户自发投稿贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 630367839@qq.com 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022年 9月 30日 3:12:48
下一篇 2022年 9月 30日 3:12:55

软件定制开发公司

相关阅读

发表回复

登录后才能评论
通知:禁止投稿所有关于虚拟货币,币圈类相关文章,发现立即永久封锁账户ID!