
Oracle9i以后,后台进程PMON自动在监听器中注册在系统参数SERVICE_NAMES中定义的服务名,SERVICE_NAMES默认为DB_NAME+DOMAIN_NAM
一开机器,发现磁盘做了扫描,估计是昨天关机遇到的问题,之后Oracle出现 ora-01172 ora-01151了 
连忙去查找资料解决,其中又遇到了ORA-12514错误,先解决这个错误的方法如下: 
listener.ora这个文件中输入下面信息: 
SID_LIST_LISTENER = 
 (SID_LIST = 
 (SID_DESC = 
 (GLOBAL_DBNAME = oracle) 服务名 
 (ORACLE_HOME = E:\oracle\product\10.2.0\db_1) db_home 
 (SID_NAME = oracle) ##这个是你要添加的服务 
 ) 
 (SID_DESC = 
 (PROGRAM = extproc) 
 (SID_NAME = PLSExtProc) 
 (ORACLE_HOME = E:\oracle\product\10.2.0\db_1) ##这个服务保证你可以使用外部过程,如C程序 
 ) 
 ) 
然后再配置tnsnames.ora文件,加入下面的内容:
 oracle = 
 (DESCRIPTION = 
 (ADDRESS_LIST = 
 (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) 
 ) 
 (CONNECT_DATA = 
 (SERVICE_NAME = test) 与上面的服务名对应 
 ) 
 ) 
在连接时你就可以这样测试下: 
 tnsping oracle 
Oracle9i以后,后台进程PMON自动在监听器中注册在系统参数SERVICE_NAMES中定义的服务名,SERVICE_NAMES默认为DB_NAME+DOMAIN_NAME。监听配置文件listener.ora中可以不必指定监听的服务名。但是,当数据库处于关闭状态下PMON进程没有启动,也就不会自动注册监听的实例名,所以使用sqlplus sys/his@orc0 as sysdba 会出现ORA-12514错误。
通过在lsnrctl中输入set display verbose,然后再通过命令service查看,服务状态为READY表示PMON自动注册的服务名,而UNKNOWN则表示该服务是手工在LISTENER.ORA中配置的数据库服务。
 至于 
这样解决了,至于介质恢复: 
 ora-01172 ora-01151了,解决办法如下: 
c:>sqlplus /nolog 
SQL> connect sys/sys@oracle as SYSDBA 
已连接 
SQL> startup mount 
ORA-01081: 无法启动已在运行的 ORACLE --- 请首先关闭 
SQL> alter database open read only; 
alter database open read only 
* 
ERROR 位于第 1 行: 
ORA-16005: 数据库需要恢复 
SQL> recover database 
完成介质恢复。 
SQL> shutdown immediate 
ORA-01109: 数据库未打开 
已经卸载数据库。 
ORACLE 例程已经关闭。 
SQL> startup 
ORACLE 例程已经启动。 
Total System Global Area 730931140 bytes 
Fixed Size 454596 bytes 
Variable Size 411041792 bytes 
Database Buffers 318767104 bytes 
Redo Buffers 667648 bytes 
数据库装载完毕。 
数据库已经打开。 
SQL> 
于是就可以咯

