学习 Oracle过程中几个常见问题的总结
2007-07-31 12:37:31 来源:WEB开发网核心提示: 删除重复记录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;
删除重复记录
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:oracleoradata
orclcontrol01.ctl’ version 57460 inconsistent
with fit
根据以上分析,我们试着修改参数文件。将参数文件中的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:oracleoradataorcl
edo01.log’,
group 2 ‘d:oracleoradataorcl
edo02.log’,
group 3 ‘d:oracleoradataorcl
edo03.log’
datafile ‘d:oracleoradataorclsystem01.dbf’,
‘d:oracleoradataorclusers01.dbf’,
‘d:oracleoradataorcl emp01.dbf’,
‘d:oracleoradataorcl ools01.dbf’,
‘d:oracleoradataorclindx01.dbf’,
‘d:oracleoradataorcldr01.dbf’,
‘d:oracleoradataorcl
bs01.dbf’;
语句已处理。
成功地重建控制文件后,我们尝试着打开数据库,但系统报错,提示需要进行介质恢复。
SVRMGR>recover datafile ‘
d:oracleoradataorclsystem01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:oracleoradataorclusers0101.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:oracleoradataorcl emp01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:oracleoradataorcl ools01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:oracleoradataorclindx01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:oracleoradataorcldr01.dbf’;
介质已恢复。
SVRMGR> recover datafile ‘d:oracleoradataorcl
bs01.dbf’;
介质已恢复。
介质恢复后,重新打开数据库,提示日志文件也需恢复。
SVRMGR> recover database until cancel;
日志已恢复。
控制文件、数据文件、日志文件全部恢复后,将三种文件同步,并打开数据库,成功地完成了数据库的恢复工作。
SVRMGR> alter database open resetlogs;
数据库已更改。
立即关闭数据库,并进行数据库的冷备份,将数据库的数据完整地保存下来。
- ››oracle 中 UPDATE nowait 的使用方法
- ››Oracle ORA-12560解决方法
- ››Oracle 10g RAC 常用维护命令
- ››Oracle如何在ASM中定位文件的分布
- ››Oracle的DBMS_RANDOM.STRING 的用法
- ››oracle 外部表导入时间日期类型数据,多字段导入
- ››Oracle中查找重复记录
- ››oracle修改用户登录密码
- ››Oracle创建删除用户、角色、表空间、导入导出等命...
- ››Oracle中登陆时报ORA-28000: the account is lock...
- ››Oracle数据库在配置文件中更改最大连接数
- ››Oracle中在pl/sql developer修改表的两种方式
赞助商链接