ORACLE 连接SQLSERVER 数据库备忘
最近工作需要,要从SQL SERVER数据库中同步提取数据。 这里采用了 Oracle Gateway 来连接,折腾了半天,终于搞定,记录下已备下次使用。
基本资料网上都可以搜很多,官网配置说明在这里
http://docs.oracle.com/cd/B28359_01/gateways.111/b31043/conf_sql.htm#CIHGADGB
1、下载安装 GateWay,,这里省略,采用默认安装就可以了。
2、配置 SID 参数文件。
每一个GateWay 实例 都对应一个SID。默认的 SID 是 dg4msql ,如果是配置多个连接,就需要用不同的SID,同样的每个SID对应一个初始化参数文件。
首先必须配置这个参数文件。
这个文件默认在这里: ORACLE_HOME\dg4msql\admin\initdg4msql.ora
注意:ORACLE_HOME 是oracle的安装目录。
“dg4msql\admin”是固定的,初始化参数文件必须放在这个目录下。
“initdg4msql.ora"是参数文件。如果用不同的SID ,则修改为“init"+SID+".ora" ..
初始化参数文件内容:
HS_FDS_CONNECT_INFO= host_name/[instance_name][/database_name]

里边 instance_name 和database_name 都是可选的. 如果instance_name 没有 但指定了database_name , 必须用两个”/",就像这样
HS_FDS_CONNECT_INFO= host_name//database_name
ORACLE_HOME\network\admin。 可以参考ORACLE_HOME\dg4msql\admin 下的样例文件listener.ora.sample。
在配置文件中增加:
SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(SID_NAME=dg4msql)
(ORACLE_HOME=E:\app\Administrator\product\11.2.0\dbhome_1)
(PROGRAM=dg4msql)
)
)
配置好的文件 看起来是这样的。。注意里边的SID_NAME,,
(PROGRAM = dg4msql) 这个不能改。
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = jwdb)
(ORACLE_HOME = E:\app\Administrator\product\11.2.\dbhome_1)
(SID_NAME = mydb)
)
#GateWay
(SID_DESC =
(SID_NAME = dg4msql)
(ORACLE_HOME = E:\app\Administrator\product\11.2.\dbhome_1)
(PROGRAM = dg4msql)
)
#GateWay
(SID_DESC =
(SID_NAME = rsdata)
(ORACLE_HOME = E:\app\Administrator\product\11.2.\dbhome_1)
(PROGRAM = dg4msql)
)
) LISTENER =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = ))
) ADR_BASE_LISTENER = E:\app\Administrator
4、配置tnsnames.ora,路径在这里 :ORACLE_HOME\network\admin,样例文件可以在这里找到。ORACLE_HOME\dg4msql\admin
dg4msql =
(DESCRIPTION=
(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=))
(CONNECT_DATA=(SID=dg4msql))
(HS=OK)
)
需要修改的就是SID=...
JWDB =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = ))
)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = jwdb) )
) DG4MSQL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = ))
)
(CONNECT_DATA = (SID = dg4msql)
)
(HS = OK)
)
RSDATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = ))
)
(CONNECT_DATA = (SID = rsdata)
)
(HS = OK)
)
在这里,一定注意有个坑~~~~~,,对于Oracle配置文件的。
主要是命名配置的格式错误。
在Oracel解析tnsname.ora文件中的命名信息时,是要求其满足一些基本规则的。从目前我们探索的情况看,两个规则是必须的:
本地命名必须顶格书写在tnsname.ora中定义的本地连接名称(如:wilson),要求一定是顶行书写的;
嵌套括号非顶格规则:在各个嵌套括号中,只有最外层的括号是允许顶行书写,其他都不允许书写;
否则就会报错!!!
说明:当服务名在tnsname.ora中非顶格书写时,Oracle不能正确解析该名称。
5、重启监听器、测试
1)命令行下面执行,lsnrctl ,进入监听管理器
2)执行reload 重新加载监听器
3)执行 status 查看状态

4)quit 退出
5) 使用 tnsping 命令检测。。。
tnsping dg4msql
如果返回OK 则配置正常。
6、创建连接
CREATE DATABASE LINK rsdata CONNECT TO "username" IDENTIFIED BY "userpassword" USING 'RSDATA';
7、测试
select * from aaa@rsdata;
说明可以使用了。
8、直接执行对应的查询操作。。。 在这里一定注意 ORACLE 中字段名和表名默认大写。 如果表明或者字段名有小写字符,请 用双引号。
如:select * from "Bys2015”@rsdata;
ORACLE 连接SQLSERVER 数据库备忘的更多相关文章
- ORACLE连接SQLSERVER
一.实验(实验成功) 1.实验目标:ORACLE连接SQLSERVER以及查询数据 2.搭建的环境: oracle 9i 9.0.2.0.1 地址:192.168.40.139 sql2000 的数据 ...
- 字符串格式连接sqlserver数据库的字段概念解释
以连接sqlserver数据库举例说明如:“Provider=SQLOLEDB.1;Password=******;Persist Security Info=True;User ID=sa;Init ...
- jsp连接sqlServer数据库教程
一.首先讲下我用的工具版本以供参考: jar包:jtds1.3.1.jar 下载地址:点击进入 数据库:SQL Server2012 服务器:Tomcat8.0 下载地址:点击进入 开发IDE工 ...
- 使用thinkphp连接sqlserver数据库时提示“系统不支持:sqlsrv”
习惯了使用php跟mysql组合,现在接到项目需要调用客户线下的系统软件的数据,具了解,这个软件的数据库是用sqlserver数据库也就是常说的mssql数据库了. 那么我现在需要用PHP连接sqls ...
- asp.net 连接sqlserver数据库
在asp.net中连接sqlserver数据库之前,首先得确保正常安装了sqlserver2008,同时有数据库. 在项目中添加一个类DB,用来专门负责执行对数据库的增删改查.在添加的过程中会弹出下面 ...
- SQLServer-----使用jTDS连接SQLServer数据库
一.jTDS一个简短的引论 jTDS100%纯Java实现的JDBC3.0驱动,它用于连接 Microsoft SQL Server(6.5.7.2000,2005,2008 和 2012)和Syba ...
- Jmeter连接SqlServer数据库进行压力测试
Jmeter连接SqlServer数据库进行压力测试 前提准备:先安装jdbc驱动 驱动下载链接地址:http://pan.baidu.com/s/1bpDpjSr 密码:v6tn 下载解压之后,讲s ...
- python连接sqlserver数据库
1.准备工作 python3.6连接sqlserver数据库需要引入pymssql模块 pymssql官方:https://pypi.org/project/pymssql/ 没有安装的话需要: pi ...
- JavaWeb连接SQLServer数据库并完成一个登录界面及其功能设计。
一.JDBC连接SQLserver数据库的步骤: 1.下载SQLserver的JDBC驱动文件——Microsoft JDBC Driver 4.0 for SQL Server 2.例如下载得到的文 ...
随机推荐
- 1、启动oracle的步骤
1.启动oracle的步骤 Linux下启动oracle分为以下两步: 1.1.启动lsnrctl监听. 1.2.启动数据库实例. 2.启动oracle监听 首先登陆服务器,切换到oracle用户. ...
- Linux服务器的那些性能参数指标
Linux服务器的那些性能参数指标 一个基于Linux操作系统的服务器运行的同时,也会表征出各种各样参数信息.通常来说运维人员.系统管理员会对这些数据会极为敏感,但是这些参数对于开发者来说也十分重要, ...
- 为什么当多个inline-block的div中,如果有的div没有内容而有的div有内容,有内容的会下沉?
为什么当多个inline-block的div中,如果有的div没有内容而有的div有内容,有内容的会下沉? 就像这样 两个div高度相同,第二个我写了一个1当作 有内容吧,它就下沉了... 奇怪... ...
- Windows 服务快捷启动命令
gpedit.msc-----组策略sndrec32-----录音机nslookup----- ip地址侦测器explorer------ 打开资源管理器logoff-------注销命令tsshut ...
- PDO操作数据库
- Cocos2d-x 核心概念 - 导演(Director)
导演类(Director) 用于管理场景对象,采用的是单例模式(单例模式能保存一致的配置信息,方便管理场景对象) 获得导演实例的语句如下 local director = cc.Director:ge ...
- 用css改变鼠标选中文字的样式
打开一个页面,选中一段文字,会出现系统默认的蓝色背景和白色文字,如下图: 那么 这种选中效果我们怎么去自定制呢,比如我想让文字选中的时候背景是绿色,文字是白色 我们在css文件中插入如下代码: ::- ...
- 虚拟现实外包公司—焰火工坊CTO团队外包难把VR真正做起来,讲故事可能将伤害产业链
CTO王明杨,带着他的焰火工坊,正在为自家VR播放器和系统的上线做最后准备.不少投资机构,有传言称包括小米在内巨头都试图染指VR领域,而上月上市的暴风影音正是倚靠VR的概念成功助推了其高股价.对此,王 ...
- 自动生成.py文件头部的C语言小程序
每次都 vi xxx.py 然后再打 #!/usr/bin/env python 等等的程序头信息感觉有点麻烦,于是便想着写一个小程序自动生成这些头信息了,顺便在 ~/.bashrc 里写入 alia ...
- ROS学习笔记(五)——建立工作空间
pre.ctl { font-family: "Liberation Mono", monospace } p { margin-bottom: 0.25cm; line-heig ...