linux下连接oracle数据库出错:ORA-12514 cannot...
今天连接数据库时出了错,监听启动正常,/ 下启动数据库也正常,用sys连接时提示出错,
数据库名是oradb,sid是oradb:
$lsnrctl start
提示:成功!
$sqlplus "/ as sysdba"
sql>startup
提示:成功!
sql>conn sys/oracle@oradb as sysdba;
报错:
ORA-12514: TNS:listener could not resolve SERVICE_NAME given in connect
descriptor!
我是这样解决的:以root身份登录,查看/oracle/product/9.2.0.4/network/admin目录
下的
listener.ora和tnsnames.ora两个配置文件的配置是否正确。
$vi tnsnames.ora
oradb =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.101)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = orcl.oradb.localdomain)
)
)
修改SERVICE_NAME = orcl.oradb.localdomain为SERVICE_NAME = oradb
保存退出
$vi listener.ora
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS =(PROTOCOL=TCP)(HOST=192.168.0.101)(PORT= 1521))
)
(ADDRESS_LIST =
(ADDRESS =(PROTOCOL=IPC)(KEY=EXTPROC))
)
)
)
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /opt/u01/app/oracle/product/9.2.0.4)
(PROGRAM = extproc)
)
)
在SID_LIST_LISTENER 中增加下列内容:
(SID_DESC =
(GLOBAL_DBNAME = oradb)
(ORACLE_HOME = /opt/u01/app/oracle/product/9.2.0.4)
(SID_NAME = oradb)
)
完整的listener.ora的内容是:
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
)
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.101)(PORT = 1521))
)
)
)
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /opt/u01/app/oracle/product/9.2.0.4)
(PROGRAM = extproc)
)
(SID_DESC =
(GLOBAL_DBNAME = oradb)
(ORACLE_HOME = /opt/u01/app/oracle/product/9.2.0.4)
(SID_NAME = oradb)
)
)
再以oracle身份登录,启动监听和数据库,连接数据库都正常了。