sql server中使用链接服务器访问oracle数据库
一、 安装配置oracle客户端
要访问orcale数据,必须在访问的客户端机器上安装oracle客户端。
Orcale有两种形式的客户端:
l 完整的客户端
包括访问服务器端数据库的基本Oracle 的 Microsoft OLE DB 访问接口需要 Oracle Client Software Support File以及 SQL*Net 。还包括用于配置客户端设置的工具、sqlplus、企业管理器等一系列的工具。
l 立即客户端(instant client)
这个客户端体积很小,但是只包括了访问orcale服务器的最基本的支撑驱动,没有设置管理工具,也找不到可用的图形界面。对客户端的设置需要手工就行。
目前orcale比较新的是oracle 10g版本,以这个版本为例。
1、 下载oracle 10 的客户端
可以到orcale官方网站下载,需要先注册,然后下载。
下载适用于Microsoft Windows (32-bit)的Oracle Database 10g Client Release 2的客户端,下载地址:http://download.oracle.com/otn/nt/oracle10g/10201/10201_client_win32.zip
2、 安装oracle 10 客户端
下载好后,解压,安装。
安装时有四个选项:
l Instantclient,相当于最小化安装。
l 管理员,完整安装。
l 运行时
l 自定义
为了管理方便,一般以管理员方式安装。
3、 配置oracle 10 客户端
在客户端主要需要配置两个设置,命名方法和服务器别名,还有一个监听程序是服务端需要用的,用来监听客户端的访问,客户端不必设置监听程序。
这些设置都能在net manager工具中进行,在oracle程序组中的“配置和移植工具”中的“net manager”。如图所示:
概要文件就是用来设置命名方法和验证方式的的
3.1. 命名方法
在窗口左面的上部下拉列表中选“命名”,左边窗口显示目前可用的方法,右边是已经选择的命名方法,几个主要的命名方法有:
l TNSNAMES表示采用TNSNAMES.ORA文件来解析
l ONAMES表示Oracle使用自己的名称服务器(Oracle Name Server)来解析,目前Oracle建议使用轻量目录访问协议LDAP来取代ONAMES
l HOSTNAME表示使用host文件,DNS,NIS等来解析
一般使用本地命名方式来解析服务器名,即使用TNSNAMES.ORA中设置的服务器名。TNSNAMES.ORA中的服务器名服务器别名中设置。
3.2. 验证方式
在下拉列表中选择“orcale高级安全性”,设置用户连接Oracle服务器时使用哪种验证方式。在下面的左边窗口显示可用的验证方式,右边是已选的验证方式,主要的验证方式有:
l NTS表示操作系统身份验证
l NONE,什么都不选表示Oracle数据库身份验证
l KERBEROS5,使用kerberos 5 验证方式
这些验证方式可以同时采用,一般采用Oracle数据库身份验证,即这里什么都不用设置即可,选了其他验证方式也不影响Oracle数据库身份验证。
3.3. 服务器别名
上面命名方法中选择了TNSNAMES本地命名方法时,在这里设置服务器的别名。
在左边窗口选“服务命名”,就可以新增和编辑本地服务器别名。这里生成的服务器别名都反映在tnsnames.ora文件中。
本地服务器命名设置的服务器实际上设置了服务器的四个主要参数:服务器主机名(可以是主机名也可以是主机ip)、服务器端口号(默认1521)、访问协议、要访问服务器上数据库服务名。
这里的exchange是客户端的服务器别名,客户端访问服务端数据库就要使用这个名称。
服务名databaseName是服务端需要访问的那个数据库的服务名。
下面就是这个服务端的ip、端口和协议(一般为TCP/IP).
设置服务器别名后,在tnsnames.ora文件中这样反映出来:
EXCHANGE =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 203.175.156.82)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = exchang)
)
)
二、 Sql server中新建指向orcacle的链接服务器
上面在客户端设置了访问oracle服务器的必要设置,客户端可以通过oracle的客户端访问orcale服务端的数据库了。
这里只讨论使用sql server的链接服务器链接oracle服务器访问数据的情况。
设置如下:
l 在sql server中新建一个链接服务器,比如链接服务器名为:oracle_exchange
l 数据访问接口选择:Microsoft OLE DB Provider for Oracle
l 产品名称:Oracle
l 数据源:就是上面步骤中建立的服务器别名,代表要访问的oracle服务器上的要访问的那个数据库。
l 在安全性中选“使用此安全上下文建立连接”,然后输入访问oracle的用户名和密码。
Ok,其他的上面没有提到的设置不需要设置。下面即可通过。
三、 在sql server中通过链接服务器访问orcale
由于orcale的服务名是直接指向到orcale服务器上的某一个数据库,所有通过链接服务器访问orcale的数据是这样的形式(指定数据库的位置不需要填):
服务器别名..所有者.数据库对象
oracle_exchange..username.tablename
sql server中使用链接服务器访问oracle数据库的更多相关文章
- sql server中创建链接服务器图解教程
转自sql server中创建链接服务器图解教程 1.展开服务器对象-->链接服务器-->右击"新建链接服务器" 注意:必须以数据库管理员身份登录(通常也就是sa帐号) ...
- 1 sql server中添加链接服务器
1 链接到另一个sql server 的实例 exec sp_addlinkedserver @server= '服务器的地址',@srvproduct='SQL Server' go 分布式查询中 ...
- Sqlserver通过链接服务器访问Oracle的那些事儿
前言: 1.不经历风雨,怎能见彩虹. 2.充分利用BaiDu.google等搜索引擎查找资料并整合分析! 3.世上无难事只怕有心人! 本文由来:笔者在研究SQLSERVER链接服务器到oracle并使 ...
- 【转】Sqlserver通过链接服务器访问Oracle的那些事儿!
原文:http://blog.sina.com.cn/s/blog_614b6f210100t80r.html 前言:1.不经历风雨,怎能见彩虹.2.充分利用BaiDu.google等搜索引擎查找资料 ...
- Sqlserver通过链接服务器访问Oracle的解决办法
转自http://blog.sina.com.cn/s/blog_614b6f210100t80r.html 一.创建sqlserver链接服务(sqlserver链接oracle) 首先sqlse ...
- Sqlserver通过链接服务器访问Oracle
工作中遇到的情况,win 7 64位操作系统的就安装64位的oracle 客户端,然后重启sql service服务后再创建sql 链接服务器.关于如何创建链接服务器请查看下面的大神的链接: http ...
- 【转】Sqlserver通过链接服务器访问Oracle的解决办法
一.创建sqlserver链接服务(sqlserver链接oracle) 首先sqlserver 链接oracle可以通过两个访问接口: “MSDAORA” 和“OraOLEDB.Oracle” 1 ...
- 64位sql server 如何使用链接服务器连接Access
原文:64位sql server 如何使用链接服务器连接Access 测试环境 操作系统版本:Windows Server 2008 r2 64位 数据库版本:Sql Server 2005 64位 ...
- [转]SQLSERVER存储过程调用不同数据库的数据_存储过程中通过链接服务器访问远程服务器
本文转自:http://blog.csdn.net/nnaabbcc/article/details/7967761 存储过程调用不同数据库的数据 在存储过程调用不同数据库的数据该如何做,比如在存储过 ...
随机推荐
- hdu3377之简单路径求最值
Plan Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- mina架构分析
使用的版本号是2.0.9 IoService分析 AbstractIoAcceptor定义了全部的public接口,并定义了子类须要实现的bindInternal函数,AbstractPollingI ...
- diff_mysql_table_exec.py
#!/usr/bin/env python #-*- encoding: utf8 -*- import mysql.connector import sys import re import dat ...
- Gradle自己定义插件
Gradle自己定义插件 在Gradle中创建自己定义插件,Gradle提供了三种方式: 在build.gradle脚本中直接使用 在buildSrc中使用 在独立Module中使用 开发Gradle ...
- csdn博客栏目加入微博关注
大家首先切换到:博客专栏,然后点击"加入专栏".然后直接复制下述代码就能够了: <a href="http://weibo.com/u/3247569660/hom ...
- listener监听器笔记
listener:三个域对象的监听器,,还有属性的变化. 监听三个域对象的创建和销毁:servletContextListenerservletRequestListenerservletsessio ...
- 一个好汉一个帮:前端UI改造
今天是周六,继续工作中. 只是,不是自己亲自参与搞代码,让一起好的同事帮我美化界面. 虽说前端,我也可以搞定, but,but呀,所有的工作都让我来搞,实在是太累太烦了. 前端,样式,目前做很多是模仿 ...
- 【u021】广义斐波那契数列
Time Limit: 1 second Memory Limit: 128 MB [问题描述] 广义的斐波那契数列是指形如an=p*an-1+q*an-2的数列.今给定数列的两系数p和q,以及数列的 ...
- java nio 缓冲区(一)
本文来自于我的个人博客:java nio 缓冲区(一) 我们以Buffer类開始对java.nio包的浏览历程.这些类是java.nio的构造基础. 这个系列中,我们将尾随<java NIO ...
- C++ public、protected、private 继承方式的区别
访问修饰符 public.protected.private,无论是修饰类内成员(变量.函数),还是修饰继承方式,本质上实现的都是可见性的控制. Difference between private, ...