打印本文 打印本文 关闭窗口 关闭窗口
oracle的几个使用技巧
作者:武汉SEO闵涛  文章来源:敏韬网  点击数2142  更新时间:2009/4/22 22:07:59  文章录入:mintao  责任编辑:mintao
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.控制文件损坏时的恢复 

  1. 根据如下错误信息,我们发现数据库只能启动实例,读控制文件时发生错误。在数据库设计的过程中,从安全的角度考虑,系统使用了三个镜像的控制文件,现在三个控制文件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.
  2. 根据以上分析,我们试着修改参数文件。将参数文件中的control_file参数修改为一个控制文件,分别使用control01、control02、control03。但数据库都无法启动,说明三个控制文件都已损坏。
  3. 由于没有控制文件的备份,我们只能采取重建控制文件的做法。
    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’;
    语句已处理。
  4. 成功地重建控制文件后,我们尝试着打开数据库,但系统报错,提示需要进行介质恢复。
    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’;
    介质已恢复。
  5. 介质恢复后,重新打开数据库,提示日志文件也需恢复。
    SVRMGR> recover database until cancel;
    日志已恢复。
  6. 控制文件、数据文件、日志文件全部恢复后,将三种文件同步,并打开数据库,成功地完成了数据库的恢复工作。
    SVRMGR> alter database open resetlogs;
    数据库已更改。
  7. 立即关闭数据库,并进行数据库的冷备份,将数据库的数据完整地保存下来。

上一页  [1] [2] 

打印本文 打印本文 关闭窗口 关闭窗口