通常情况下,我们的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也能实现跨服务器访问数据,但它是基于已建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。
本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!
本文来源:https://www.yuntue.com/post/153574.html | 云服务器网,转载请注明出处!