oracle用户下表空间的运用_第1页
oracle用户下表空间的运用_第2页
oracle用户下表空间的运用_第3页
oracle用户下表空间的运用_第4页
oracle用户下表空间的运用_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一)用户表空间错误:在启动数据库时出现ORA-01157,ORA-01110或操作系统级错误例如ORA-07360,在关闭数据库(使用shutdownnormal或shutdownimmediate)时将导致错误ORA-01116,ORA-01110以及操作系统级错误ORA-07368解决:以下有两种解决方案:用户的表空间可以被轻易地重建即最近导出的对象是可用的或表空间中的对象可以被轻易地重建等.在这种情况下,最简单的方法是offline并删除该数据文件,删除表空间并重建表空间以及所有的对象.svrmgrl>startupmountsvrmgrl>alterdatabasedatafilefilenameofflinedrop;svrmgrl>alterdatabaseopen;svrmgrl>droptablespacetablespace_nameincludingcontents;重建表空间及所有对象.用户的表空间不能够被轻易地重建在大多数情况下,重建表空间是不可能及太辛苦的工作.方法是倒备份及做介质恢复.如果您的系统运行在NOARCHIVELOG模式下,则只有丢失的数据在onlineredolog中方可被恢复。步骤如下:1) Restorethelostdatafilefromabackup2) svrmgrl>startupmount3) svrmgrl>selectv1.group#,member,sequence#,first_change#fromv$logv1,v$logfilev2wherev1.group#=v2.group#;4) 如果数据库运行在NOARCHIVELOG模式下则:svrmgrl>selectfile#,change#fromv$recover_file;如果CHANGE#大于最小的FIRST_CHANGE#则数据文件可以被恢复。如果CHANGE#小于最小的FIRST_CHANGE#则数据文件不可恢复。恢复最近一次的全备份或采用方案一.5) svrmgrl>recoverdatafilefilename;6) 确认恢复成功7) svrmgrl>alterdatabaseopenresetlogs;只读表空间无需做介质恢复,只要将备份恢复即可.唯一的例外是:表空间在最后一次备份后被改为read-write模式表空间在最后一次备份后被改为read-only模式在这种情况下,均需进行介质恢复)临时表空间临时表空间并不包含真正的数据,恢复的方法是删除临时表空间并重建即可.三) 系统表空间如果备份不可用,则只能采用重建数据库的方法四) 回滚表空间有两种情况:1、 数据库已经完全关闭(使用shutdownimmediate或shutdown命令)1) 确认数据库完全关闭2) 修改init.ora文件,注释"rollback-segment”3) svrmgrl>startuprestrictmount4) svrmgrl>alterdatabasedatafilefilenameofflinedrop;5) svrmgrl>alterdatabaseopen;基于出现的结果:"statementprocessed"转(7)〃0RA-00604,0RA-00376,0RA-01110〃转(6)6) svrmgrl>shutdownimmediate修改init.ora文件,增加如下一行:_corrupted_rollback_segments=(,...)svrmgrl>startuprestrict7) svrmgrl>droptablespacetablespace_nameincludingcontents;8) 重建表空间及回滚段9) svrmgrl>altersystemdisablerestrictedsession;10) 修改init.ora文件2、 数据库未完全关闭(数据库崩溃或使用shutdownabort命令关闭数据库)1) 恢复备份2) svrmgrl>startupmount3) svrmgrl>selectfile#,name,statusfromv$datafile;svrmgrl>alterdatabasedatafilefilenameonline;4) svrmgrl>selectv1.group#,member,sequence#,first_change#fromv$logv1,v$logfilev2wherev1.group#=v2.group#;5) svrmgrl>selectfile#,change#fromv$recover_file;见一方案2-46) svrmgrl>recoverdatafilefilename;7) svrmgrl>alterdatabaseopen;3、 数据库处于打开状态1) 删除回滚段和表空间2) 重建表空间和回滚段五) 控制文件恢复所有的控制文件均被破坏

将备份的控制文件拷贝至原目录下对于RAWDEVICE,则:ddif='con.bak'of='/dev/rdrd/drdl'seek=128并非所有的控制文件均被破坏用其他的控制文件启动数据库ORACLE有四种文件:数据文件、日志文件、控制文件、参数文件通过以下视图显示这些文件信息:v$database,v$datafile,v$logfilev$controlfilev$parameter监听器日志文件:监听器参数文件:TNS连接文件:监听器日志文件:监听器参数文件:TNS连接文件:Sql*Net环境文件:警告日志文件:基本结构:建立数据字典视图:建立审计用数据字典视图:建立快照用数据字典视图:c:\orant\NET80\admin\listener.orac:\orant\NET80\admin\Tnsnames.orac:\orant\NET80\admin\sqlnet.orac:\orant\RDBMS80\trace\orclALRT.LOGc:\orant\RDBMS80\admin\Standard.sqlc:\orant\RDBMS80\admin\CATALOG.SQLc:\orant\RDBMS80\admin\CATAUDIT.SQLc:\orant\RDBMS80\admin\catsnap.sql回滚段管理一直是ORACLE数据库管理的一个难题,本文通过实例介绍ORACLE回滚段的概念,用法和规划及问题的解决。回滚段概述回滚段用于存放数据修改之前的值(包括数据修改之前的位置和值)。回滚段的头部包含正在使用的该回滚段事务的信息。一个事务只能使用一个回滚段来存放它的回滚信息,而一个回滚段可以存放多个事务的回滚信息。回滚段的作用事务回滚:当事务修改表中数据的时候,该数据修改前的值(即前影像)会存放在回滚段中,当用户回滚事务(ROLLBACK)时,ORACLE将会利用回滚段中的数据前影像来将修改的数据恢复到原来的值。事务恢复:当事务正在处理的时候,例程失败,回滚段的信息保存在重做日志文件中,ORACLE将在下次打开数据库时利用回滚来恢复未提交的数据。读一致性:当一个会话正在修改数据时,其他的会话将看不到该会话未提交的修改。而且,当一个语句正在执行时,该语句将看不到从该语句开始执行后的未提交的修改(语句级读一致性)。当ORACLE执行SELECT语句时,ORACLE依照当前的系统改变号(SYSTEMCHANGENUMBER-SCN)来保证任何前于当前SCN的未提交的改变不被该语句处理。可以想象:当一个长时间的查询正在执行时,若其他会话改变了该查询要查询的某个数据块,ORACLE将利用回滚段的数据前影像来构造一个读一致性视图。事务级的读一致性ORACLE一般提供SQL语句级(SQLSTATEMENTLEVEL)的读一致性,可以用以下语句来实现事务级的读一致性。SETTRANSACTIONREADONLY;或:SETTANNSACTIONSERIALIZABLE;以上两个语句都将在事务开始后提供读一致性。需要注意的是,使用第二个语句对数据库的并发性和性能将带来影响。回滚段的种类系统回滚段:当数据库创建后,将自动创建一个系统回滚段,该回滚段只用于存放系统表空间中对象的前影像。非系统回滚段:拥有多个表空间的数据库至少应该有一个非系统回滚段,用于存放非系统表空间中对象的数据前影像。非系统回滚段又分为私有回滚段和公有回滚段,私有回滚段应在参数文件的ROLLBACKSEGMENTS参数中列出,以便例程启动时自动使其在线(ONLINE)。公有回滚段一般在OPS(ORACLE并行服务器)中出现,将在例程启动时自动在线。DEFERED回滚段:该回滚段在表空间离线(OFFLINE)时由系统自动创建,当表空间再次在线(ONLINE)时由系统自动删除,用于存放表空间离线时产生的回滚信息。回滚段的使用分配回滚段:当事务开始时,ORACLE将为该事务分配回滚段,并将拥有最少事务的回滚段分配给该事务。事务可以用以下语句申请指定的回滚段:SETTRANSTRACTIONUSEROLLBACKSEGMENTrollback_segment事务将以顺序,循环的方式使用回滚段的区(EXTENTS),当当前区用满后移到下一个区。几个事务可以写在回滚段的同一个区,但每个回滚段的块只能包含一个事务的信息。例如(两个事务使用同一个回滚段,该回滚段有四个区):1、 事务在进行中,它们正在使用回滚段的第三个区;2、 当两个事务产生更多的回滚信息,它们将继续使用第三个区;3、 当第三个区满后,事务将写到第四个区,当事务开始写到一个新的区时,称为翻转(WRAP);4、 当第四个区用满时,如果第一个区是空闲或非活动(使用该区的所有事务完成而没有活动的事务)的,事务将接着使用第一个区。回滚段的扩张(EXTEND)当当前回滚段区的所有块用完而事务还需要更多的回滚空间时,回滚段的指针将移到下一个区。当最后一个区用完,指针将移到U第一个区的前面。回滚段指针移到下一个区的前提是下一个区没有活动的事务,同时指针不能跨区。当下一个区正在使用时,事务将为回滚段分配一个新的区,这种分配称为回滚段的扩展。回滚段将一直扩展到该回滚段区的个数到达回滚段的参数MAXEXTENTS的值时为止。回滚段的回收和OPTIMAL参数OPTIMAL参数指明回滚段空闲时收缩到的位置,指明回滚段的OPTIMAL参数可以减少回滚段空间的浪费。创建回滚段语法:CREATE[PUBLIC]ROLLBACKSEGMENTrollback_segment[TABLESPACEtablespace][STORAGE([INITIALinteger[K|M]][NEXTinteger[K|M]][MINEXTENTSinteger][MAXTENTS{integer|UNLIMITED}][OPTIMAL{integer[K|M]|NULL}])]注:回滚段可以在创建时指明PRIVATE或PUBLIC,一旦创建将不能修改。MINEXTENTS必须大于等于2PCTINCREASE必须是0OPTIMAL如果要指定,必须大于等于回滚段的初始大小(由MINEXTENTS指定)建议:一般情况下,INITIAL=NEXT设置OPTIMAL参数来节约空间的使用不要设置MAXEXTENTS为UNLIMITED回滚段应创建在一个特定的回滚段表空间内例:CREATEROLLBACKSEGMENTrbs01TABLESPACErbsSTORAGE(INITIAL100KNEXT100KMINEXTENTS10MAXEXTENTS500OPTIMAL1000K);使回滚段在线当回滚段创建后,回滚段是离线的,不能被数据库使用,为了使回滚段被事务利用,必须将回滚段在线。可以用以下命令使回滚段在线:ALTERROLLBACKSEGMENTrollback_segmentONLINE;例:ALTERROLLBACKSEGMENTrbs01ONLINE;为了使回滚段在数据库启动时自动在线,可以在数据库的参数文件中列出回滚段的名字。例如在参数文件中加入以下一行:ROLLBACK_SEGMENT=(rbs01,rbs02)修改回滚段的存储参数可以使用ALTERROLLBACKSEGMENT命令修改回滚段的存储参数(包括OPTIMAL,MAXEXTENTS)o语法:ALTERROLLBACKSEGMENTrollback_segment[STORAGE([NEXTinteger[K|M]][MINEXTENTSinteger][MAXEXTENTS{integer|UNLIMITED}][OPTIMAL{integer[K|M]|NULL}])]例:ALTERROLLBACKSEGMENTrbs01STORAGE(MAXEXTENTS1000);回收回滚段的空间如果指定了回滚段的OPTIMAL参数,ORACLE将自动回收回滚段到OPTIMAL指定的位置。用户也可以手动回收回滚段的空间。语法:ALTERROLLBACKSEGMENTrollback_segmentSHRINK[TOinteger[K|M]];说明:如果不指明TOinteger的数值,ORACLE将试图回收到OPTIMAL的位置。例:ALTERROLLBACKSEGMENTrbs01SHRINKTO2M;使回滚段离线为了达到以下两个目的将要回滚段离线:阻止新的事务使用该回滚段;该回滚段必须删除。语法:ALTERROLLBACKSEGMENTrollback_segmentOFFLINE;例:ALTERROLLBACKSEGMENTrbs01OFFLINE;说明:如果有事务正在使用该回滚段,运行该命令后,回滚段的状态将是PENDINGOFFLINE。事务结束后,状态将改为OFFLINE,可以通过V$ROLLSTAT查询回滚段的状态。删除回滚段当回滚段不再需要或要重建以改变INITIAL,NEXT或MINEXTENTS参数时,可以将其删除。要删除回滚段,不许使该回滚段离线。语法:DROPROLLBACKSEGMENTrollback_segment;DROPROLLBACKSEGMENTrbs01;查询回滚段的信息所用数据字典:DBA_ROLLBACK_SEGS可以查询的信息:回滚段的标识(SEGMENT_ID)、名称(SEGMENT_NAME)、所在表空间(TABLESPACE_NAME)、类型(OWNER)、状态(STATUS)。例:SQL>SELECTsegment_name,tablespace_name,owner,statusFROMdba_rollbac

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论