怎么远程连接oracle数据库
第一种情况:
若oracle服务器装在本机上,那就不多说了,连接只是用户名和密码的问题了。不过要注意环境变量%ORACLE_HOME%/network/admin/是否设置。
第二种情况:
本机未安装oracle服务器,也未安装oracle客户端。但是安装了pl sql development、toad sql development、sql navigator等管理数据库的工具。在虚拟机或者另一台电脑上安装了oracle服务器,也就是虚拟机或者另一台电脑此时作为服务器。
这种情况下,本人以pl sql development远程连接ORACLE服务端数据库为例:
1、在安装oracle服务器的机器上搜索下列文件:
ocidll
ocijdbc10dll
ociw32dll
orannzsbb10dll
oraocci10dll
oraociei10dll
sqlnetora
tnsnamesora
classes12jar
ojdbc14jar
把这些找到的文件复制放到一个文件夹,如 oraclient,将此文件夹复制到客户端机器上。如放置路径为 D:oraclient。
2、配置tnsnamesora,修改其中的数据库连接串。
oracledata = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192168058)(PORT = 1521)) (CONNECT_DATA = (SERVICE_NAME = oracledata) )
其中,oracledata是要连接的服务名;HOST = 192168058,是服务器IP地址;PORT = 1521是端口号。
3、添加第一个环境变量,名为TNS_ADMIN,值为tnsnamesora文件所在路径(如:D:oraclient,特别是重装后或其它操作,忘了TNS_ADMIN变量,plsql登陆就会报无法解析指定的连接标识符),这是为了能够找到上面说的tnsnamesora。这步是最重要的。
添加第二个环境变量(可有可无):“NLS_LANG = SIMPLIFIED CHINESE_CHINAZHS16GBK”,(AMERICAN_AMERICAUS7ASCII 是ASCII编码类型,其它类型可自己到服务器看一下或网上查找一下)(本步骤暂时要做对,如果编码不对,会产生乱码)。
4、下载并安装PL SQL Developer配置应用:
打开PL SQL Developer,登入界面点取消,进入后选择菜单栏 tools->preferences->connection :
Oracle Home=D:oracleclient OCI library=D:oracleclientocidll
5、再次打开plsql则会在database中有oracledata 选项输入用户名密码就可以登陆。
第三种情况:
本机未安装ORACLE服务器,但是安装了oracle客户端,也安装了pl sql development、toad sql development、sql navigator等管理数据库的工具。在虚拟机或者另一台电脑上安装了oracle服务器,也就是虚拟机或者另一台电脑此时作为服务器。
这种情况下,本人以pl sql development远程连接oracle服务端数据库为例:
1、打开oracle客户端中的net manager,配置要远程连接的数据库名、IP地址等,如果net manager中没有要远程连接的数据库名,则新建即可。
2、其他步骤与第二种情况中的2---5相同。
第四种情况:
本机未安装oracle服务器,也未安装pl sql development、toad sql development、sql navigator等管理数据库的工具,但是安装了oracle客户端。在虚拟机或者另一台电脑上安装了ORACLE服务器,也就是虚拟机或者另一台电脑此时作为服务器。
这种情况下,本人以oracle客户端中的sqlplus远程连接oracle服务端数据库为例:
1、打开oracle客户端中的net manager,配置要远程连接的数据库名、IP地址等,如果net manager中没有要远程连接的数据库名,则新建即可。
2、同第二种情况中的步骤二。
3、同第二种情况中的步骤三。
4、打开sqlplus:
(1)如果用sys用户登入,则用户名:sys 密码:xxxxxx 主机字符串:要连接的数据库名 as sysdba,登入即可。
(2)如果用其他用户登入,则用户名:xxx 密码:xxxxxx 主机字符串:要连接的数据库名,登入即可。
注意事项:
1、服务器端和客户端防火墙需要关闭;
2、我们经常会遇到***服务无法启动,那么需要打开Net Configuration Assistant修复,或者新建***服务。
3、数据库密码如果忘了怎么办?按照以下方法修改密码即可:
开始-->运行-->cmd
输入 :sqlplus /nolog 回车
输入 :connect / as sysdba 回车
用户解锁 : alter user system account unlock 回车
修改密码:alter user system identified by manager
4、怎样判断数据库是运行在归档模式下还是运行在非归档模式下?
进入dbastudio,历程--〉数据库---〉归档查看。
5、另外,如果本机和别的机子均安装了oracle服务器端,那么本机如果要连接别的机子,就必须修改tnsnamesora
ORACLE客户端连服务器注意事项
1 通SQLNET协议ORACLE客户端连服务器般需要配置sqlnetoratnsnamesora,initora
默认目录$ORACLE_HOME/network/admin 目录
设置环境变量TNS_ADMIN指向想用sqlnetoratnsnamesora目录
例:
TNS_ADMIN=/home/oracle/config/901;export TNS_ADMIN
sqlnetora文件决定找数据库服务器别名式
默认参数
参数SQLNETAUTHENTICATION_SERVICES= (NONE,NTS)表明用户连接Oracle服务器使用哪种验证式NONE表示Oracle身份验证NTS表示操 作系统身份验证两种式并用
ORA_DBA组域用户本用户需要Oracle用户名密码登录Oracle且该组用户登录数据库都具SYSDBA权限(实 例建立类似组ORA_SID_DBA其SID指实例名)同理:ORA_OPER组员具SYSOPER角色权限
登录式 sqlplus / as sysdba
或者sqlplus nolog,SQL>connect / as sysdba
NAMESDEFAULT_DOMAIN = WORLD
NAMESDIRECTORY_PATH = (TNSNAMES, ONAMES, HOSTNAME)
表明解析客户端连接所用主机字符串式
TNSNAMES表示采用TNSNAMESORA文件解析;
ONAMES表示使用自名称服务器(Oracle Name Server)解析目前Oracle建议使用轻量目录访问协议LDAP取代ONAMES;
HOSTNAME表示使用host文件DNSNIS等解析;
ORACLE客户端服务器默认域名需要用#号注释第行
#NAMESDEFAULT_DOMAIN = WORLD
使起作用
NAMESDIRECTORY_PATH指定找服务器别名顺序 (本tnsnamesora文件, 命名服务器, 主机名式)
服务器sqlnetora设置检查客户端否alive间间隔
sqlnetexpire_time = 10
initoraRemote_Login_Passwordfile身份验证影响
三选值:
NONE:默认值指示Oracle系统使用密码文件通操作系统进行身份验证特权用户拥SYSORASYSOPER权限EXCLUSIVE:
1表示数据库实例使用密码文件
2允许SYSORASYSOPER权限赋值给SYS外其用户
SHARED:
1表示数据库实例使用密码文件
2允许SYSORASYSOPER权限赋值给SYS外其用户
所要操作系统身份登录Remote_Login_Passwordfile应该设置NONE
登录用户ORA_DBA组ORA_OPER组员登录数据库需要Oracle创建前操作系统用户相同用户名前用户域用 户则名称:domainname\yourname,本计算机用户则名称:computername\yourname
创建:
create "domainname\yourname" identified externally;
操作系统修改HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0面添加AUTH_PREFIX_DOMAIN值设FALSE,创建Oracle用户忽略 掉域名
种式initora参数影响数据库何匹配windows用户Oracle用户os_authent_prefix = ""
缺省空Oracle8i前该参数使用OPS$作用户名前缀(Oracle用户名度限制30字符)
tnsnamesora文件写数据库服务器别名详细内容几种写:
# 般写
APPDB =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192168035)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = appdb)
)
)
# 明确标明用dedicated式连接数据库
APPD=
(DESCRIPTION=
(ADDRESS=(PROTOCOL=TCP)(HOST=192168035)(PORT=1521))
(CONNECT_DATA=
(SERVICE_NAME=appdb)
(SERVER=DEDICATED)))
# listener端口做均衡负载式连接数据库
APPS =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192168035)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = 192168035)(PORT = 1856))
)
(CONNECT_DATA =
(SERVICE_NAME = appdb)
)
)
# 注意:数据库服务器用MTS客户端程序需要用database link明确指明客户端用dedicated直连式,
# 遇跟布式环境关ORACLE BUG
# 般情况数据库服务器用直接连接些除非实数据库连接数接近1000
2 /etc/hosts (UNIX)
或者windows\hosts(WIN98) winnt\system32\drivers\etc\hosts (WIN2000)
客户端需要写入数据库服务器IP址主机名应关系
127001 localhost
192168035 oracledb oracledb
192168045 tomcat tomcat
2028410193 bj_db bj_db
些候我配置第步tnsping 数据库服务器别名显示功
sqlplus username/password@servicename通,jdbc thin link 通候,
定要忘客户端做步原能DNS服务器没设置服务器IP址主机名应关系
同私IPInternet公IP私IP写前面公IP写面
编辑前留备份增加行用复制粘贴避免编辑hosts空格或者tab字符错误
3 UNIXORACLE数据库环境OS客户端需要配置面两环境变量
ORACLE_SID=appdb;export ORACLE_SID
TWO_TASK=appdb;export TWO_TASK
指定默认目标数据库
享:
1
喜欢
0
赠金笔
阅读(2478)┊ 评论 (0)┊ 收藏(0) ┊禁止转载 ┊ 喜欢▼ ┊打印┊举报
已投稿:
排行榜
前篇:Delphi IdHTTP1载文件防止假死
篇:我博客今6岁246我领取元博主徽章北京科兰
通过配置本地数据库的tns配置文件实现:
去oracle安装目录下oracle\product\1020\db_2\NETWORK\ADMIN\ 找到tnsnamesora,用记事本打开,里边有远程数据库的tns连接配置串如下
ORCL23 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192168323)(PORT = 1521))
)
(CONNECT_DATA =
(SID = ORCL)
)
)
添加好ip、端口和目标数据库的实例名(SID),然后确保tns名称(ORCL23)在整个文档中唯一,保存后打开数据库连接工具,输入远程数据库上的用户名密码,选择数据库对象为你配置的连接名就可以了。
还有一种方法就是配置Database Link,详情参考下帖
http://moonightsiteyecom/blog/568895
1、安装oracle客户端;
2、在开始菜单选择Net Configure Assistant配置本地服务名;
3、按照提示一步一步往下配置就可以了;
0条评论