zyqin-Every thing would be!

  DonewsBlog  |  Donews首页  |  Donews社区  |  Donews邮箱  |  我的首页  |  联系作者  |  聚合   |  登录
  109篇文章 :: 0篇收藏:: 52篇评论:: 3个Trackbacks

公告

文章

收藏

相册

My Links

搜索引擎

友情链接

存档


正在读取评论……


 

问题:我的的数据库以前都是正常的,但是今天突然发现数据库无法连接,报出ORA-00257错误,这是为什么,请问应该怎样解决。

解答:从Oracle9i开始,借助于UNDO日志文件提供了闪回查询的功能,由于功能也有一定的局限性,也就是说依赖于UNDO日志的事务不能被覆盖,所以在Oracle10g开始又采用了一种新的FlashBack日志来实现这个功能,而且更为强大,可以将数据库退回到过去某个时间点去。这个文件默认最大为2g。但是在一段时间过后,很快就达到了2G,这个时候就会出现ORA-00257错误了。

如何去解决呢,有两种方法,第一种就是关闭闪回日志的功能,这种对于开发环境中不失为一种好方法,因为开发环境中,并不追求数据的可安全性的。大家可以通过下面的语句改变。

 

alter database flashback off

 

 

第二种方法就是增大闪回日志文件的最大大小。示例如下:

 

alter system set DB_RECOVERY_FILE_DEST_SIZE=10g

此时,你可以去查看v$flash_recovery_area_usage视图中的使用率情况,这个时候发现使用率(PERCENT_SPACE_USED列的值)已经大大降低了。再通过如下语句去查看系统日志文件情况。

 

select * from v$log

至此redo日志文件可以正常写入,问题解决。

 



Trackback: http://tb.donews.net/TrackBack.aspx?PostId=1347481


[点击此处收藏本文]  发表于2008年09月17日 2:28 PM




正在读取评论……

发表评论

大名:
网址:
验证码
评论