连接到Oracle的几种命名方式

简介:

从事Oracle相关工作的人,每天都会使用各种工具连接到Oracle数据库,比如:SQL*Plus、PL/SQL、TOAD、SQLDeveloper等等,下面就列举了几种连接到Oracle的方式,本例中使用的是SQL*Plus为例。

1、Easy Connect命名方式

这种方式是一种很简单的方式,它不需要去访问tnsnames.ora文件,而去直接连接数据库。

语法:

CONNECT username@[//]host[:port][/[service_name][:server]][/instance_name]]
Enter password: password

使用示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[oracle@rhel6 admin]$ sqlplus  /nolog
 
SQL*Plus: Release 11.2.0.1.0 Production on Thu Jun 1 15:34:21 2017
 
Copyright (c) 1982, 2009, Oracle.  All rights reserved.
 
idle>conn zx@192.168.56.2:1522 /orcl
ERROR:
ORA-12504: TNS:listener was not given the SERVICE_NAME  in  CONNECT_DATA
 
idle>conn zx@ '192.168.56.2:1522/orcl'
Enter password: 
Connected.
zx@ORCL>conn zx /zx @ '192.168.56.2:1522/orcl'
Connected.
zx@ORCL>conn zx /zx @192.168.56.2:1522 /orcl
Connected.
zx@ORCL>conn zx@192.168.56.2:1522 /orcl
ERROR:
ORA-12504: TNS:listener was not given the SERVICE_NAME  in  CONNECT_DATA
 
 
Warning: You are no longer connected to ORACLE.

从上面的例子中可以看到在Linux平台上使用Easy Connect连接时,如果连接串中没有密码,则需要把连接串使用引号引起来,否则会报错ORA-12504。而连接串中包含密码时则不需要使用引号引起来。

这是一种很简单的连接数据库的方法,不需要配置任何文件。

更详细的信息参考:http://docs.oracle.com/cd/E11882_01/network.112/e41945/naming.htm#NETAG255

2、Local命名方式

Local命名方式需要把网络服务名添加到tnsnames.ora文件中,每个网络服务器对应一个连接描述符。这种方法也是工作中最常会用到的方法。

下面是一个连接描述符的例子:

orcl=
(DESCRIPTION= 
  (ADDRESS=(PROTOCOL=tcp)(HOST=192.168.56.2)(PORT=1522))
  (CONNECT_DATA= 
     (SERVICE_NAME=orcl)))

tnsnames.ora文件一般存放在$ORACLE_HOME/network/admin目录下。

使用语法:

CONNECT username@net_service_name
Enter password: password

连接示例:

1
2
3
4
5
6
7
8
9
10
[oracle@rhel6 admin]$ sqlplus  /nolog
 
SQL*Plus: Release 11.2.0.1.0 Production on Thu Jun 1 15:49:55 2017
 
Copyright (c) 1982, 2009, Oracle.  All rights reserved.
 
idle>conn zx@orcl
Enter password: 
Connected.
zx@ORCL>

从上面的例子中可以看到,在连接串中只需要指定对应的连接服务名就可以连接到对应的数据库。

可以使用OEM、netmgr、netca对tnsnames.ora进行配置。

tnsnames.ora中各参数的含义详细描述详见:http://docs.oracle.com/cd/E11882_01/network.112/e10835/tnsnames.htm#NETRF007

3、Directory命名方式

详细参考:http://docs.oracle.com/cd/E11882_01/network.112/e41945/naming.htm#NETAG265

4、External命名方式

详细参考:http://docs.oracle.com/cd/E11882_01/network.112/e41945/naming.htm#NETAG277





      本文转自hbxztc 51CTO博客,原文链接:http://blog.51cto.com/hbxztc/1931361,如需转载请自行联系原作者




相关文章
|
6月前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
1220 28
|
Oracle 关系型数据库 数据库
已解决:idea 连接 oracle 数据库 避雷
已解决:idea 连接 oracle 数据库 避雷
142 2
|
12月前
|
SQL Oracle 关系型数据库
Python连接Oracle
Python连接Oracle
136 0
|
Oracle 数据可视化 关系型数据库
Oracle数据库安装及使用Navicat连接oracle2
Oracle数据库安装及使用Navicat连接oracle
160 1
|
Oracle 关系型数据库
Navicat 连接Oracle ORA-28547: connection to server failed, probable Oracle Net admin error
Navicat 连接Oracle ORA-28547: connection to server failed, probable Oracle Net admin error
513 0
|
Oracle 关系型数据库 数据库
实时计算 Flink版产品使用问题之连接到Oracle数据库但无法读取到数据,是什么导致的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
Oracle Java 关系型数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
311 6
|
Oracle Java 关系型数据库
SpringBoot整合Mybatis连接Oracle数据库
SpringBoot整合Mybatis连接Oracle数据库
SpringBoot整合Mybatis连接Oracle数据库
|
Oracle 安全 关系型数据库
Oracle数据库安装及使用Navicat连接oracle1
Oracle数据库安装及使用Navicat连接oracle
243 0
|
消息中间件 Oracle 关系型数据库
实时计算 Flink版操作报错合集之在连接Oracle 19c时报错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
273 0