首页 > 资讯列表 > 编程/数据库 >> 数据库操作教程

跨数据库实现数据交流

数据库操作教程 2022-09-23 17:44:58 转载来源: 网络整理/侵权必删

通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况

通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。

一、同SQL SERVER

这个最简单。直接在表名前加上"[数据库名]."就可以了。

例:

SELECT * FROM [DestinationDBName].dbo.DestinationTableName

二、跨SQL SERVER

 主要介绍两种方法:

(一)通过链接服务器

1.先执行系统存储过程 sp_addlinkedserver :

EXEC sp_addlinkedserver @server='DestinationDBAlias',--目标数据库的别名,在连接并登录后,就可以用它来访问数据@srvproduct='',@provider='SQLOLEDB',@datasrc='DestinationServerIPServerName'--通常用"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.DestinationTableNameSELECT * FROM OPENROWSET('SQLOLEDB',--provider_name'DestinationServerIP';'UserName';'Password',--provider_string(datasource;user_id;password)'SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName')--query_string

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

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

标签: 数据库 实现 数据 交流


声明:本文内容来源自网络,文字、图片等素材版权属于原作者,平台转载素材出于传递更多信息,文章内容仅供参考与学习,切勿作为商业目的使用。如果侵害了您的合法权益,请您及时与我们联系,我们会在第一时间进行处理!我们尊重版权,也致力于保护版权,站搜网感谢您的分享!

站长搜索

http://www.adminso.com

Copyright @ 2007~2024 All Rights Reserved.

Powered By 站长搜索

打开手机扫描上面的二维码打开手机版


使用手机软件扫描微信二维码

关注我们可获取更多热点资讯

站长搜索目录系统技术支持