The log file for database '' is full

来源:互联网 发布:中国人工智能发展现状 编辑:程序博客网 时间:2024/06/10 16:40

-- 第一步:清空日志 DUMP TRANSACTION [YZGA] WITH NO_LOG-- 第二步:截断事务日志 BACKUP LOG [YZGA] WITH NO_LOG -- 第三步:收缩数据库 DBCC SHRINKDATABASE([YZGA]) ==========================================================日志: 不推荐使用BACKUPLOGWITH TRUNCATE_ONLY 或WITH NO_LOG。应使用简单恢复模式自动截断事务日志。 有关更多信息,请参阅在 http://go.microsoft.com/fwlink/events.asp 的帮助和支持中心。 NO_LOG | TRUNCATE_ONLY 通过放弃活动日志以外的所有日志,无需备份复制日志即可删除不活动的日志部分,并截断日志。该选项会释放空间。因为并不保存日志备份,所以没有必要指定备份设备。NO_LOG 和 TRUNCATE_ONLY 是同义的。 注意: 在 SQL Server 的未来版本中将删除该选项。应避免使用该选项进行新的开发工作,并计划修改当前使用它的应用程序。 使用 NO_LOG 或 TRUNCATE_ONLY 截断日志后,记录在日志中的更改不可恢复。为了进行恢复,请立即执行BACKUPDATABASE 以执行完整备份或完整差异备份。 注意: 尽管可用该选项手动截断事务日志,但是我们极力建议您不要这样做,因为这会将日志链断开。在下一次完整备份或完整差异备份之前,将无法为数据库提供媒体故障保护。只在非常特殊的情况下才手动截断日志,并立即创建数据备份。 注意: 如果不想进行日志备份,请将数据库设置为简单恢复模式。

SQL Server 2008 日志收缩

SQL code
ALTER DATABASE 数据库名SET RECOVERY SIMPLEGO-- Shrink the truncated log file to 1 MB.DBCC SHRINKFILE (数据库日志文件名, 1)GO--日志文件名可以通过下面的语句查找select * from sys.database_files-- Reset the database recovery model.ALTER DATABASE 数据库名SET RECOVERY FULLGO

SQL Server 2005
SQL code
DUMP TRANSACTION 数据库名 WITH NO_LOGBACKUP LOG 数据库名 WITH NO_LOGDBCC SHRINKDATABASE (数据库名)


原创粉丝点击