SQL Server链接其他数据库服务器的方法

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:
在实际应用中经常碰到要对两个数据库(不在同一台主机上)进行关联操作,在Oracle中提供了这种机制,可以链接其他主机上的Oracle数据库。
同样的在SQL Server2005中也可以链接到其他的SQL Server数据库,并且通过Ole DB还可以链接到Oracle、Sybase等其他不同的数据库,方便用户的操作和维护。

在Microsoft SQL Server Management Studio的工具中提供了图形界面的操作:

 不过其中的一些参数的填写比较麻烦,我这里就以链接SQL Server和Oracle为例说一下
(命令的方式,只列出最简单的命令,对一些可有可无的属性的设置我把它去掉了)

1、链接SQL Server 数据库
这个是相对简单的。参见如下的sql语句
None.gif USE [master]
None.gifGO
None.gifEXEC master.dbo.sp_addlinkedserver @server 
=  N ' DBSERVER ' , @srvproduct = N ' SQL Server '
None.gifGO
None.gifUSE [master]
None.gifGO
None.gifEXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname 
=  N ' DBSERVER ' , @locallogin  =  N ' sa ' , @useself  =  N ' False ' , @rmtuser  =  N ' sa ' , @rmtpassword  =  N ' 1 '
None.gifGO
主要就是调用了两个存储过程:
sp_addlinkedserver是加入数据库链接,其中server的参数是另外一台SQL Server服务器的名称
sp_addlinkedsrvlogin是加入对应的远程数据库的用户名,rmtuser和rmtpassword是远程数据库的用户名和密码

下面就可以直接在本地查询远程数据库的表了:
None.gif  select  *  from [DBSERVER].[helpdesk].[dbo].[Messages];

2、链接Oracle数据库
要链接Oracle数据库,首先要在本地安装Oracle的客户端,并且配置好Oracle的别名(别名的配置我这里就不多说了,很简单的)
然后同样的调用上面的两个存储过程:
None.gif USE [master]
None.gifGO
None.gifEXEC master.dbo.sp_addlinkedserver @server 
=  N ' GSPRING ' , @srvproduct = N ' Oracle ' , @provider = N ' MSDAORA ' , @datasrc = N ' gspring '
None.gifGO
None.gifUSE [master]
None.gifGO
None.gifEXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname 
=  N ' GSPRING ' , @locallogin  =  N ' sa ' , @useself  =  N ' False ' , @rmtuser  =  N ' user1 ' , @rmtpassword  =  N ' 1 '
None.gifGO
其中server是链接数据库的名称,datasrc是本地配置的oracle的别名。

下面就可以直接在本地查询远程oracle数据库的表了:
None.gif select  *  from [GSPRING]..[user1].[table1];
其中user1是table1表的owner
要注意的就是SqlServer中访问一张表的全路径是四层,那么访问oracle时对于没有的要用一个空的.代替

其他:
1、本地配置的所有链接可以在sysservers表中查到:
None.gif select  *  from sys.sysservers;

2、访问远程数据库表时也可以先在本地建一个同义词,然后就可以像在本地一样的访问了:
None.gif USE [master]
None.gifGO
None.gifCREATE SYNONYM [dbo].[linktable] FOR [DBSERVER].[helpdesk].[dbo].[Messages];
None.gifGO
None.gif
None.gifselect 
*  from linktable;

3、在配置oracle时如果出现其他错误,请参见微软的解决方案(我配置过程中一个问题都没有出现,难道是我RP太好了03.gif):http://support.microsoft.com/kb/280106/zh-cn



    本文转自永春博客园博客,原文链接:http://www.cnblogs.com/firstyi/archive/2007/08/09/849494.html,如需转载请自行联系原作者

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
6天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
42 10
|
16天前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
15 0
|
6天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
59 6
|
10天前
|
关系型数据库 MySQL 数据库
卸载云服务器上的 MySQL 数据库
卸载云服务器上的 MySQL 数据库
30 0
|
2天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
5天前
|
关系型数据库 MySQL 数据库连接
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
28 11
|
6天前
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
|
10天前
|
弹性计算 前端开发 Java
使用阿里云 mqtt serverless 版本超低成本快速实现 webscoket 长链接服务器
使用阿里云 MQTT Serverless 可轻松实现弹性伸缩的 WebSocket 服务,每日成本低至几元。适用于小程序消息推送的 MQTT P2P 模式。前端需注意安全,避免 AK 泄露,采用一机一密方案。后端通过调用 `RegisterDeviceCredential` API 发送消息。示例代码包括 JavaScript 前端连接和 Java 后端发送。
100 0
|
10天前
|
SQL 安全 Java
SQL server 2017安装教程
SQL server 2017安装教程
14 1
|
14天前
|
数据库 SQL 索引
什么是数据库 SQL Execution Plan
什么是数据库 SQL Execution Plan
10 0