Oracle数据库常见问题及解决方案大全

数据库 Oracle
本文我们总结了一些在Oracle数据库使用过程中的常见问题,并对其进行了分析,给出了解决方案,希望能够对您有所帮助。

Oracle数据库在使用的过程中常常会遇到这样或那样的问题,而这些问题常常又使我们感到很困惑,本文我们总结了Oracle数据库在使用过程中的一些问题,并给出了解决方法,下面我们就开始分析一下这些问题。

一、oracle监听启动后,立即停止。

TNS-12545: 因目标主机或对象不存在,连接失败。

TNS-12560: TNS: 协议适配器错误。

TNS-00515: 因目标主机或对象不存在,连接失败。

32-bit Windows Error: 1004: Unknown error。

不再监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=//./pipe/EXTPROC0ipc)))。

原因是我安装了oracle之后,又修改了主机名。

解决方法:

1.直接修改listener.ora

路径是: oracle安装目录/product/10.2.0/db_1/NETWORK/ADMIN/listener.ora.

修改HOST 为主机名或者IP.

2.通过 Net Manager,在 监听程序/LISTENER 下直接修改主机即可  

二.错误码及解决办法

1.ORA:-12545:因目标主机和对象不存在,连接失败。

错误代码ORA-12545表示网络连接串(即tnsnames.ora文件中的HOST处)中使用的机器名和IP地址不存在,重新修改和重新连接即可。

2.ORA-12651:TNS:没有监听器。

该信息说明所要连接的服务器没有启动监听进程Listener(该进程为Oracle服务器上操作系统进程,监听进程没有启动时,服务器可以正常进行,但是客户端不能与服务器产生连接。这时可以在服务器使用操作系统命令lsnrctl正常起启动监听进程)。

3.ORA-00600:internal error code,arguments:[num],[?],[?],[?],[?] 。

产生原因:这种错误通常为ORACLE的内部错误,只对OSS和ORACLE开发有用。ORA-600的错误经常伴随跟踪文件的状态转储(系统状态和进程状态),系统状态存储将包括ORACLE RDBMS持有的当前对象的信息,进程状态转储则将显示特殊进程持有的对象,当进程符合了某错误条件时,经常是由于一些信息取自它持有的一个块,如果我们知道这些错误进程持有的块,就容易跟踪问题的来源。 

解决方法:一般来说出现这个错误我们本身是无法解决的,只有从提高系统本身各方面来解决这个内部问题,如增加硬件设备,调整系统性能,使用OPS(当然OPS从某种意义上说并不是一种好的解决方式)等。ORA-600错误的第一个变量用于标记代码中错误的位置(代码中的每个部分的第一变量都不一样),从第二个到第五个变量显示附加信息,告诉OSS代码在哪里出现了错误

4.ORA-12560  协议适配器错误:

有关ORA-12560: TNS:协议适配器错误的问题

①.检查Terminal Service, 远程桌面是不是起因。

②.环境变量set oracle_sid=需要的服务名。

③.listener.ora, tnsnames.ora等内机器名或者IP地址是否正确。

④.netstat –a检查端口是否被占用。

⑤.检查注册表HKEY_LOCAL_MACHINE/Software/Oracle/Home0新增字符串USE_SHARED_SOCKET=TRUE, 重新启动服务。

5.ORA-28595: Invalid DLL Path   调用外部DLL出错

原因:A setting in Oracle's LISTENER.ORA file on the server hosting the RDBMS is missing.

解决办法:

(1).Locate the active LISTENER.ORA file on the server.  By default, it will be on the Oracle RDBMS drive in the path ../ora92/network/admin.

(2).Inspect the file and locate all entries associated with "SID_DESC".  Each such entry should have the following option associated with it:

(ENVS = "EXTPROC_DLLS=ANY")

(3).Add the above line to any entry where it is missing.

(4).Restart the Oracle Listener Service (or reboot the server which will in turn restart Oracle).

例子:

The example LISTENER.ORA file below shows a valid configuration for the server named "WOODY" (using TCP/IP on Port 1521) with the correct ENVS entries highlighted:

# LISTENER.ORA Network Configuration File: C:/oracle/ora92/network/admin/listener.ora

# Generated by Oracle configuration tools.

 

LISTENER =  
 
(DESCRIPTION_LIST =  
 
(DESCRIPTION =  
 
(ADDRESS_LIST =  
 
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))  
 
)  
 
(ADDRESS_LIST =  
 
(ADDRESS = (PROTOCOL = TCP)(HOST = woody)(PORT = 1521))  
 
)  
 
)  
 
)  
 
SID_LIST_LISTENER =  
 
(SID_LIST =  
 
(SID_DESC =  
 
(SID_NAME = PLSExtProc)  
 
(ORACLE_HOME = C:/oracle/ora92)  
 
(PROGRAM = extproc)  
 
(ENVS = "EXTPROC_DLLS=ANY")  
 
)  
 
(SID_DESC =  
 
(GLOBAL_DBNAME = WOODY)  
 
(ORACLE_HOME = C:/oracle/ora92)  
 
(SID_NAME = WOODY)  
 
(ENVS = "EXTPROC_DLLS=ANY")  
 
)  
 
)  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.

 

6.在控制面板中启动服务,出现以下错误:

服务:在本地计算机无法启动OracleOraDb10g_home1TNSListener 服务。

错误3:系统找不到指定的路径。

查看属性发现,OracleOraDb10g_home1TNSListener 服务的可执行文件的路径为空。

解决办法:

开始-->运行REGEDIT -->进入注册表找到HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/OracleOraDb10g_home1TNSListener

发现ImagePath关键值没有了,新建一个名为ImagePath的可扩充字符串值,编辑字符串的数值数据为:Oracle安装路径/BIN/TNSLSNR

7.错误描述:本地计算机上的OracleOraDb10g_home1TNSListener服务启动后又停止了。一些服务自动停止,如果它们没有什么可做的,例如 "性能日志和警报 "服务。

解决办法:C:/oracle/product/10.2.0/db_1/NETWORK/ADMIN/listener.ora把这这文件里的内容改下 HOST=你的计算机名字。

关于Oracle数据库的问题及解决方法就介绍到这里,如果您想了解更多关于Oracle数据库的内容,可以看一下这里的文章:http://database.51cto.com/oracle/,相信一定会带给您收获的!

【编辑推荐】

  1. Oracle RAC启动与关闭时的一些注意事项
  2. 一些很实用的Oracle数据库优化策略总结篇
  3. 怎样用Oracle的ODP.NET创建实体数据模型
  4. Oracle 11g客户端在Linux系统上的配置步骤详解
  5. 一个系统崩溃造成Oracle数据库无法启动的恢复实例
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2019-10-08 16:05:19

Redis数据库系统

2010-08-31 16:09:04

DIV+CSS

2011-05-25 09:45:40

Oracle数据库

2024-07-08 08:45:41

2011-05-26 14:49:50

ORACLE数据库

2009-11-18 16:10:00

2016-09-27 21:14:53

JavaURL

2014-01-07 13:54:02

HadoopYARN

2011-07-28 11:28:21

SQL Server数注册表编辑器

2021-05-18 08:21:38

React HooksReact前端

2010-09-01 14:51:12

CSSIEFirefox

2025-01-09 15:28:30

2018-01-31 17:50:33

数据库MySQL优化

2024-10-30 11:00:00

Python列表索引

2024-05-24 10:56:24

PythonURL代码

2011-07-12 16:42:41

2010-08-26 12:59:29

marginCSS

2019-04-04 13:11:37

React内存泄露memory leak

2010-08-04 10:20:30

Flex组件开发

2023-04-12 11:32:33

网络
点赞
收藏

51CTO技术栈公众号