Chinaunix首页 | 论坛 | 博客
  • 博客访问: 92138281
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-03-30 22:58:40

来源:赛迪网    作者:Alizze

从Oracle 10g开始,Oracle已经开始支持简化连接方式,这种方法简化了连接Oracle数据库的步骤,Oracle用户不再需要配置TNSNAMES.ORA就可以直接连接到远端的数据库。

以下是一个使用简化连接的例子:

SQL> conn system/test@172.25.13.227/ora11g_p.ytk-thinkpad已连接。
SQL>

大家可以发现在屏幕上直接显式输入密码是很难保障安全的,假如这里省略了密码:

SQL> conn system@172.25.13.227/ora11g_p.ytk-thinkpad
ERROR:
ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务

警告: 您不再连接到 ORACLE。

Oracle连接报错,尝试将整个连接字符串用引号包围,仍然出现错误:

SQL> conn "system@172.25.13.227/ora11g_p.ytk-thinkpad"输入口令:
ERROR:
ORA-01017: invalid username/password; logon denied

大家可以发现这里的错误是由于Oracle发现@后面还包含了/,因此没有将@后面的字符串作为连接符。

相对于后面的情况,Oracle把整个字符串作为用户名,因此才会报错。

正确的方式是将引号仅包含@后面的字符:

SQL> conn system@"172.25.13.227/ora11g_p.ytk-thinkpad"输入口令:已连接。
SQL>

以下是在SQLPLUS中使用CONNECT命令的情况,假如是在操作系统命令行下请使用SQLPLUS命令,方法和上面的类似,但要使用到转义符。

先看Windows环境下:

E:\>sqlplus system@172.25.13.227/ora11g_p.ytk-thinkpad

SQL*Plus: Release 10.2.0.1.0 - Production on 星期一 2月 11 01:46:56 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

ERROR:
ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务

请输入用户名:
ERROR:
ORA-01017: 用户名/口令无效; 登录被拒绝

请输入用户名:
ERROR:
ORA-01017: 用户名/口令无效; 登录被拒绝


SP2-0157: 在 3 次尝试之后无法连接到 ORACLE, 退出 SQL*Plus

E:\>sqlplus system@"172.25.13.227/ora11g_p.ytk-thinkpad"

SQL*Plus: Release 10.2.0.1.0 - Production on 星期一 2月 11 01:47:08 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

ERROR:
ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务

请输入用户名:
ERROR:
ORA-01017: 用户名/口令无效; 登录被拒绝

请输入用户名:
ERROR:
ORA-01017: 用户名/口令无效; 登录被拒绝


E:\>sqlplus system@"""172.25.13.227/ora11g_p.ytk-thinkpad"""

SQL*Plus: Release 10.2.0.1.0 - Production on 星期一 2月 11 01:47:23 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

输入口令:

连接到:
Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL>

在Linux环境下只是转义符不同:

[oracle@yangtk ~]$ sqlplus system@\"172.25.13.227/ora11g_p.ytk-thinkpad\"

SQL*Plus: Release 11.1.0.6.0 - Production on Sun Jan 6 09:30:45 2008

Copyright (c) 1982, 2007, Oracle. All rights reserved.

Enter password: 

Connected to:
Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL>
阅读(319) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~