当前位置:Gxlcms > 数据库问题 > 跨数据库数据交流

跨数据库数据交流

时间:2021-07-01 10:21:17 帮助过:3人阅读

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

跨数据库数据交流

标签:

人气教程排行