当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 解析:在SQL Server下数据库链接的使用

MSSQL
一个分页存储过程代码
Sql Server 2000 行转列的实现(横排)
sql2000挂起无法安装的问题的解决方法
完美解决MSSQL"以前的某个程序安装已在安装计算机上创建挂起的文件操作"
SQL Server数据库的修复SQL语句
分页存储过程代码
批量执行sql语句的方法
一条SQL语句搞定Sql2000 分页
SQL Server 海量数据导入的最快方法
SQL Select语句完整的执行顺序
MSSQL 清空数据库的方法
mssql自动备份及自动清除日志文件服务器设置
Sql 语句学习指南
.NET Framework SQL Server 数据提供程序连接池
对有自增长字段的表导入数据注意事项
SQL Server导入、导出、备份数据方法
sql server 临时表 查找并删除的实现代码
该行已经属于另一个表 的解决方法
SQL 注入式攻击的本质
SQL 平均数统计

MSSQL 中的 解析:在SQL Server下数据库链接的使用


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 75 ::
收藏到网摘: n/a

某些情况下:我们希望在一个SQL Server下访问另一个sqlserver数据库上的数据,或者访问其他oracle数据库上的数据,要想完成这些操作,我们首要的是创建数据库链接。

数据库链接能够让本地的一个SQLserver登录用户映射到远程的一个数据库服务器上,并且像操作本地数据库一样。那么怎么创建数据库链接呢?我现在有两种方法可以实现。

第一种:在SQL Server 企业管理器中,建立,这个比较简单的,首先在 安全性--〉数据库链接 上点右键 ,在出现的菜单中点 新建数据库链接 ,然后会弹出一个界面,需要我们填写的有:链接服务器(这是一个名字,自己根据情况自行定义,以后就要通过他进行远程访问了),提供程序名称(这个就是选择数据驱动,根据数据库类型来选择,不能乱选,否则链接不上的),数据源(对于SQL server就是远程数据库服务器的主机名或者IP,对于 oracle 就是在 oracle net config 中配置的别名),安全上下文用户和口令(也就是远程服务器的用户和口令)。

第二种:利用系统存储过程

创建一个SQL Server对sqlserver的数据库链接:

exec sp_addlinkedserver  'link_northsnow','',

'SQLOLEDB','远程服务器主机名或域名或ip地址'

exec sp_addlinkedsrvlogin 'link_northsnow','

false',null,'用户名','用户口令'
 
创建一个SQL server对Oracle的数据库链接:

exec sp_addlinkedserver 'link_ora', 'Oracle',

'MSDAORA', 'oracle数据库服务器别名'

exec sp_addlinkedsrvlogin 'link_ora',

false, 'sa', '用户名', '用户口令'

有了数据库链接我们就可以使用了。对于sqlserver和oracle中的使用方法是有区别的。

对于SQL server:

create view v_lhsy_user as select *

from link_northsnow.lhsy.dbo.sys_user

select * from v_lhsy_user
 
其中lhsy为远程的数据库名

sys_user为表名

对于Oracle:

create view vvv as select * from

link_ora..NORTHSNOW.SYS_USER

select * from vvv;
 
其中northsnow为远程oracle数据库服务器的一个用户名,SYS_USER为该用户在该服务器上的一个表,要非常注意的是:数据库链接(link_ora)后面有两个点(..),再往后面必须全部大写,查询的对象一般为表格或者视图,不能查询同义词。

要想删除数据库链接,也有两种方法,

一种方法是在企业管理器中操作。

另一种是用系统存储过程:

exec sp_dropserver