ORA-01219错误

通过pl/sql dev连接数据库是报数据库初始化中,或者已关闭.

查看服务器,服务及监听一切正常.

查找资料如下:

===

http://blog.sina.com.cn/s/blog_6efbe0220100v1qj.html

ORA-01219:database not open:queriesallowed on fixed tables/views only

“ORA-01219:数据库未打开:仅允许在固定表/视图中查询”的警告窗口!    

解决办法:

登录Oracle SQL*Plus

username  sys

password   sa

String    orclas sysdba

这一段是找出打开数据库的时候报错的地方

SQL> select open_modefrom v$database;

OPEN_MODE
----------
MOUNTED

SQL> alter databaseopen;
alter database open
*
ERROR at line 1:
ORA-01157: cannot identify/lock data file 4 - see DBWR tracefile
ORA-01110: data file 4: '/data/app/oradata/ora237/users01.dbf'

 

这里就是讲'/data/app/oradata/ora237/users01.dbf'这个文件出问题

我们要做的就是删掉这个残留文件

进行下一步:

SQL> alter databasedatafile '/data/app/oradata/ora237/users01.dbf' offline drop;

Database altered.

SQL> alter databaseopen;

Database altered.

SQL>

注意,当你同时出现ora-01110这个错误,那么你要检查你数据文件存在不

按上述方法处理是在 执行 alter database open 时出现如下错误:

ORA-01172: 线程 1 的恢复停止在块 105 (在文件 2 中)
ORA-01151: 如果需要, 请使用介质恢复以恢复块和还原备份

搜索到如下资料:http://jackyrong.iteye.com/blog/1566213

一开机器,发现磁盘做了扫描,估计是昨天关机遇到的问题,之后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>

  于是就可以咯

按照描述进行:如下操作

SQL*Plus: Release 10.2.0.3.0 - Production on 星期三 6月 19 13:25:59 2013

Copyright (c) 1982, 2006, Oracle.  All Rights Reserved.


连接到:
Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - Production
With the Partitioning, OLAP and Data Mining options

SQL> select open_mode from v$database;

OPEN_MODE
----------
MOUNTED

SQL> alter database open;
alter database open
*
第 1 行出现错误:
ORA-01172: 线程 1 的恢复停止在块 105 (在文件 2 中)
ORA-01151: 如果需要, 请使用介质恢复以恢复块和还原备份


SQL> startup mount
ORA-01081: 无法启动已在运行的 ORACLE - 请首先关闭它
SQL> alter database open read only;
alter database open read only
*
第 1 行出现错误:
ORA-16005: 数据库需要恢复


SQL> recover database;
完成介质恢复。
SQL> shutdown immediate;
ORA-01109: 数据库未打开


已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup
ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务
SQL> startup
ORA-24324: 未初始化服务句柄
ORA-01041: 内部错误, hostdef 扩展名不存在
SQL> 

执行 startup后 出现错误

ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务

重启了 服务及监听后

SQL> startup
ORA-24324: 未初始化服务句柄
ORA-01041: 内部错误, hostdef 扩展名不存在

按照 网上讲述的 修改 tns 为 none的方法 无效.

随之重新配置了本地命名服务后重启一切OK!

你可能感兴趣的:(ORA-01219错误)