Oracle实用技巧

时间:2007-01-12 12:18:22   来源:  作者:  点击:次  出处:技术无忧
关键字:Orac

 ------------------ ---- --------------------
  AAAIRIAAQAAAAJqAAA 1111 aaaa
  AAAIRIAAQAAAAJqAAB 1112 aaaa
  AAAIRIAAQAAAAJqAAC 1113 aaaa
  AAAIRIAAQAAAAJqAAD 1114 aaaa
  AAAIRIAAQAAAAJqAAE 1111 aaaa
  AAAIRIAAQAAAAJqAAF 1112 aaaa
  AAAIRIAAQAAAAJqAAG 1113 aaaa
  AAAIRIAAQAAAAJqAAH 1114 aaaa
  8 rows selected
  查出重复记录
  SQL> select rowid,bm,mc from a where a.rowid!=(select max(rowid) from a b where a.bm=b.bm and a.mc=b.mc);
  ROWID BM MC
  ------------------ ---- --------------------
  AAAIRIAAQAAAAJqAAA 1111 aaaa
  AAAIRIAAQAAAAJqAAB 1112 aaaa
  AAAIRIAAQAAAAJqAAC 1113 aaaa
  AAAIRIAAQAAAAJqAAD 1114 aaaa
  删除重复记录
  SQL> delete from a a where a.rowid!=(select max(rowid) from a b where a.bm=b.bm and a.mc=b.mc);
  删除4个记录.
  SQL> select rowid,bm,mc from a;
  ROWID BM MC
  ------------------ ---- --------------------
  AAAIRIAAQAAAAJqAAE 1111 aaaa
  AAAIRIAAQAAAAJqAAF 1112 aaaa
  AAAIRIAAQAAAAJqAAG 1113 aaaa
  AAAIRIAAQAAAAJqAAH 1114 aaaa
  5.控制文件损坏时的恢复
  根据如下错误信息,我们发现数据库只能启动实例,读控制文件时发生错误。在数据库设计的过程中,从安全的角度考虑,系统使用了三个镜像的控制文件,现在三个控制文件version号不一致。
  SVRMGRL>startup
  oracle instance started
  total system global area 222323980 bytes
  fixed size 70924 bytes
  variable size 78667776 bytes
  database buffers 143507456 bytes
  redo buffers 77824 bytes
  ORA-00214: controlfile ‘d:/oracle/oradata/orcl/control01.ctl’ version 57460 inconsistent with file ‘d:/oracle/oradata/orcl/control02.ctl’ version 57452.
  根据以上分析,我们试着修改参数文件。将参数文件中的control_file参数修改为一个控制文件,分别使用control01、control02、control03。但数据库都无法启动,说明三个控制文件都已损坏。
  由于没有控制文件的备份,我们只能采取重建控制文件的做法。
  D:/>svrmgrl
  Oracle Server Manager Release 3.1.6.0.0 - Production
  版权所有 (c) 1997,1999,Oracle Corporation。保留所有权利。
  Oracle8i Enterprise Edition Release 8.1.6.0.0 - Production
  With the Partitioning option
  JServer Release 8.1.6.0.0 - Production
  SVRMGR> connect internal
  连接成功。
  SVRMGR> shutdowm abort
  已关闭 ORACLE 实例。
  SVRMGR> startup nomount
  已启动 ORACLE 实例。
  系统全局区域合计有 108475660个字节
  Fixed Size 70924个字节
  Variable Size 46116864个字节
  Database Buffers 62210048个字节
  Redo Buffers 77824个字节
  SVRMGR>create controlfile reuse database orcl noresetlogs archivelog
  Logfile group 1 ‘d:/oracle/oradata/orcl/redo01.log’,
  group 2 ‘d:/oracle/oradata/orcl/redo02.log’,
  group 3 ‘d:/oracle/oradata/orcl/redo03.log’
  datafile ‘d:/oracle/oradata/orcl/system01.dbf’,
  ‘d:/oracle/oradata/orcl/users01.dbf’,
  ‘d:/oracle/oradata/orcl/temp01.dbf’,
  ‘d:/oracle/oradata/orcl/tools01.dbf’,
  ‘d:/oracle/oradata/orcl/indx01.dbf’,
  ‘d:/oracle/oradata/orcl/dr01.dbf’,
  ‘d:/oracle/oradata/orcl/rbs01.dbf’;
  语句已处理。
  成功地重建控制文件后,我们尝试着打开数据库,但系统报错,提示需要进行介质恢复。
  SVRMGR>recover datafile ‘d:/oracle/oradata/orcl/system01.dbf’;
  介质已恢复。
  SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/users0101.dbf’;
  介质已恢复。
  SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/temp01.dbf’;
  介质已恢复。
  SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/tools01.dbf’;
  介质已恢复。
  SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/indx01.dbf’;
  介质已恢复。
  SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/dr01.dbf’;
  介质已恢复。
  SVRMGR> recover datafile ‘d:/oracle/oradata/orcl/rbs01.dbf’;
  介质已恢复。
  介质恢复后,重新打开数据库,提示日志文件也需恢复。
  SVRMGR> recover database until cancel;
  日志已恢复。
  控制文件、数据文件、日志文件全部恢复后,将三种文件同步,并打开数据库,成功地完成了数据库的恢复工作。
  SVRMGR> alter database open resetlogs;
  数据库已更改。
  立即关闭数据库,并进行数据库的冷备份,将数据库的数据完整地保存下来。想自己动手组装电脑吗?想了解市场行情吗?来技术无忧DIY资讯一切烦脑都没有!


文章评论

共有 0 位网友发表了评论 此处只显示部分留言 点击查看完整评论页面

特别推荐
300x250广告位招租