天天看点

删除DUAL表后的处理

删除DUAL表后的处理   Oracle系统中dual表是一个“神秘”的表,网上有很多网友都对该表进行了测试,该表只有一行一列,其实该表和系统中的其他表一样,一样可以执行插入、更新、删除操作,还可以执行drop操作。但是不要去执行drop表的操作,否则会使系统不能用,数据库起不了,会报Database startup crashes with ORA-1092错误。 此时也不要慌乱,可以通过执行以下步骤来进行恢复。可以用sys用户登陆。 SQL> create pfile=’d:/pfile.bak’ from spfile SQL> shutdown immediate 在d:/pfile.bak文件中最后加入一条:replication_dependency_tracking = FALSE 重新启动数据库: SQL> startup pfile=’d:/pfile.bak’ SQL> create table “sys”.”DUAL”      ( “DUMMY” varchar2(1) )      pctfree 10 pctused 4; SQL> insert into dual values(‘X’); SQL> commit; SQL> Grant select on dual to Public; 授权成功。   SQL> select * from dual;   D - X   SQL> shutdown immediate 数据库已经关闭。 已经卸载数据库。 ORACLE 例程已经关闭。 SQL> startup ORACLE 例程已经启动。   Total System Global Area 135338868 bytes Fixed Size                    453492 bytes Variable Size              109051904 bytes Database Buffers            25165824 bytes Redo Buffers                  667648 bytes 数据库装载完毕。 数据库已经打开。 SQL>   OK, 下面就可以正常使用了。