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