您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

ora-01172 ora-01151的处理

2024/6/22 1:55:48发布29次查看
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>
于是就可以咯

该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product