Sybase数据库清除日志的做法

lxypeter 2010-06-07

Sybase数据库清除日志的做法

最近在项目中使用Sybase,发现数据库日志满了,所以在网上淘了两条语句,拿出来贴一下,

1.打开查询分析器,输入命令

DUMPTRANSACTION数据库名WITHNO_LOG

2.再打开企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。



清除Log有两种方法:



  1.自动清除法



  开放数据库选项TruncLogonChkpt,使数据库系统每隔一段时间自动清除Log。此方法的优点是无须人工干预,由SQL Server自动执行,并且一般不会出现Log溢满的情况;缺点是只清除Log而不做备份。



  2.手动清除法



  执行命令“dumptransaction”来清除Log。以下两条命令都可以清除日志:



dumptransactionwithtruncate_only

dumptransactionwithno_log



  通常删除事务日志中不活跃的部分可使用“dumptransactionwithtrancate_only”命令,这条命令写进事务日志时,还要做必要的并发性检查。SYBASE提供“dumptransactionwithno_log”来处理某些非常紧迫的情况,使用这条命令有很大的危险性,SQL Server会弹出一条警告信息。为了尽量确保数据库的一致性,你应将它作为“最后一招”。



  以上两种方法只??清除日志,而不做日志备份,若想备份日志,应执行“dumptransactiondatabase_nametodumpdevice”命令。



PS:附一个更好的方法



先分离数据库后,直接删除日志以后,再在查询分析器里用



execsp_attach_single_file_db'数据库名','.mdf文件路径'

命令附加数据库。OVER.在别的地方看到的不错。

相关推荐