欢迎来到天天文库
浏览记录
ID:54861840
大小:37.00 KB
页数:15页
时间:2020-04-23
《Oracle物理结构故障的处理方法.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、个人收集整理,勿做商业用途-快速删除重复的记录做项目的时候,一位同事导数据的时候,不小心把一个表中的数据全都搞重了,也就是说,这个表里所有的记录都有一条重复的。这个表的数据是千万级的,而且是生产系统。也就是说,不能把所有的记录都删除,而且必须快速的把重复记录删掉。对此,总结了一下删除重复记录的方法,以及每种方法的优缺点。为了陈诉方便,假设表名为,表中有三列1,2,3,其中1,2是主键,并且,1,2上加了索引。1、通过创建临时表可以把数据先导入到一个临时表中,然后删除原表的数据,再把数据导回原表,语句如下:(*
2、);清空表记录*将临时表中的数据插回来。这种方法可以实现需求,但是很明显,对于一个千万级记录的表,这种方法很慢,在生产系统中,这会给系统带来很大的开销,不可行。2、利用在中,每一条记录都有一个,在整个数据库中是唯一的,确定了每条记录是中的哪一个数据文件、块、行上。在重复的记录中,可能所有列的内容都相同,但不会相同。语句如下:(a,b>112=2)如果已经知道每条记录只有一条重复的,这个语句适用。但是如果每条记录的重复记录有N条,这个N是未知的,就要考虑适用下面这种方法了。3、利用或函数这里也要使用,与上面不同
3、的是结合或函数来实现。语句如下a (()b112=2)这里使用也可以或者用下面的语句a < (()b112=2)这里如果把换成的话,前面的子句中需要把"<"改为">"15/15个人收集整理,勿做商业用途跟上面的方法思路基本是一样的,不过使用了,减少了显性的比较条件,提高效率。语句如下: (()t 1,2 );(1,2)(12 12 (*)>1) ( () 12 (*)>1)还有一种方法,对于表中有重复记录的记录比较少的,并且有索引的情况,比较适用。假定1,2上有索引,并且表中有重复
4、记录的记录比较少,语句如下4、利用,提高效率物理结构故障的处理方法:物理结构故障是指构成数据库的各个物理文件损坏而导致的各种数据库故障。这些故障可能是由于硬件故障造成的,也可能是人为误操作而引起。所以我们首先要判断问题的起因,如果是硬件故障则首先要解决硬件问题。在无硬件问题的前提下我们才能按照下面的处理方发来进一步处理。控制文件损坏:控制文件记录了关于的重要配置信息,如数据库名、字符集名字、各个数据文件、日志文件的位置等等信息。控制文件的损坏,会导致数据库异常关闭。一旦缺少控制文件,数据库也无法启动,这是一种
5、比较严重的错误。可以通过查询数据库的日志文件来定位损坏了的控制文件。日志文件位于$.损坏单个控制文件:1.确保数据库已经关闭,如果没有用下面的命令来关闭数据库:>;2.查看初始化文件$,确定所有控制文件的路径。3.用操作系统命令将其它正确的控制文件覆盖错误的控制文件。4.用下面的命令重新启动数据库>;5.用适当的方法进行数据库全备份。损坏所有的控制文件:1.确保数据库已经关闭,如果没有用下面的命令来关闭数据库:>;2.从相应的备份结果集中恢复最近的控制文件。对于没有采用带库备份的点可以直接从磁带上将最近的控制
6、文件备份恢复到相应目录;对于采用带库备份的点用相应的脚本来恢复最近的控制文件。3.用下面的命令来创建产生数据库控制文件的脚本:>;>;4.15/15个人收集整理,勿做商业用途修改第三步产生的文件,将其中关于创建控制文件的一部分语句拷贝出来并做些修改,使得它能够体现最新的数据库结构。假设产生的文件名字为.注意:文件的具体路径可以在执行完第3)步操作后查看$文件来确定。5.用下面命令重新创建控制文件:>;>;>;6.用适当的方法进行数据库全备份。重做日志文件损坏:数据库的所有增、删、改都会记录入重做日志。如果当前
7、激活的重做日志文件损坏,会导致数据库异常关闭。非激活的重做日志最终也会因为日志切换变为激活的重做日志,所以损坏的非激活的重做日志最终也会导致数据库的异常终止。在中每组重做日志只有一个成员,所以在下面的分析中只考虑重做日志组损坏的情况,而不考虑单个重做日志成员损坏的情况。确定损坏的重做日志的位置及其状态:1.如果数据库处于可用状态:*v$;>*v$;2.如果数据库处于已经异常终止:>;>*v$;>*v$;其中,的状态为表示这组日志文件出现已经损坏;状态为:表示重做日志文件处于非激活状态;:表示重做日志文件处于激
8、活状态;:表示是重做日志为当前正在使用的日志文件。损坏的日志文件处于非激活状态:1.删除相应的日志组:>;2.重新创建相应的日志组:>(’’,…);损坏的日志文件处于激活状态且为非当前日志:1.清除相应的日志组:>;损坏的日志文件为当前活动日志文件:用命令清除相应的日志组:>;如果清除失败,则只能做基于时间点的不完全恢复。打开数据库并且用适当的方法进行数据库全备份:>;部分数据文件损坏:15/15个
此文档下载收益归作者所有