赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索

快速掌握SqlServer下数据库链接的使用

发布时间:2007.07.31 07:55     来源:赛迪网    作者:shuijing

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

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

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

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

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

exec sp_addlinkedserver  'link_northsnow','',
'SQLOLEDB','远程服务器主机名或域名或ip地址'
exec sp_addlinkedsrvlogin 'link_northsnow','
false',null,'用户名','用户口令'

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

exec sp_addlinkedserver 'link_ora', 'Oracle', 
'MSDAORA', 'oracle数据库服务器别名'
exec sp_addlinkedsrvlogin 'link_ora',
 false, 'sa', '用户名', '用户口令'

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

对于sqlserver:

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

数据库链接名称,'droplogins' 。(责任编辑:卢兆林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 信息产业部启动网站备案系统数据库清查工作 (07-30) · 细化解析:SQL Server2005查询计划指南 (07-30)
· 不要在SQL Server中盲目地追求一句处理 (07-30) · 解析SQLServer怎样才能访问sybase中的表 (07-30)
· 怎样终止:SQL Server数据库的恢复过程 (07-29) · 怎样才能重建 sybsystemprocs系统数据库 (07-29)
· 轻松学会:配置SQL Server来做远程备份 (07-29) · SQL/ASE SERVER 移植到同种平台的系统上 (07-29)
· XP上不能安装SQL Server2000吗 (07-27) · 通过分析SQL语句的执行计划优化SQL(三) (07-27)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管