前端之家收集整理的这篇文章主要介绍了
跨数据库实现数据交流,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。
一、同sql SERVER
这个最简单。直接在表名前加上"[数据库名]."就可以了。
例:
sql;">
SELECT * FROM [DestinationDBName].dbo.DestinationTableName
二、跨sql SERVER
主要介绍两种方法:
(一)通过链接服务器
1.先执行系统存储过程 sp_addlinkedserver :
<div class="jb51code">
<pre class="brush:sql;">
EXEC sp_addlinkedserver
@server='DestinationDBAlias',--目标数据库的别名,在连接并登录后,就可以用它来访问数据
@srvproduct='',@provider='sqlOLEDB',@datasrc='DestinationServerIP\ServerName'--通常用"IP\端口名"组成,如果服务器上只装了一个MSsql SERVER,或者装了多个MS sqlSERVER,但要访问的是默认端口,就不用加端口名
sql;">
EXEC sp_addlinkedsrvlogin
@rmtsrvname='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致
@useself='false',@locallogin=NULL,@rmtuser='UserName',@rmtpassword='Password'
sql;">
EXEC sp_dropserver
@server='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致
@droplogins='droplogins'
sql;">
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