欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

跨数据库实现数据交流

程序员文章站 2022-07-12 07:50:27
通常情况下,我们的crud操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。 一、同sql serv...

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

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