SqlServer 数据库日志无法收缩处理过程

Posted 你好柴九

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SqlServer 数据库日志无法收缩处理过程相关的知识,希望对你有一定的参考价值。

今天按常用方法收缩一个测试用的数据库日志,发现没法收缩!
dbcc sqlperf(logspace)
技术分享图片

USE [dbname]
GO
 
ALTER DATABASE [dbname] SET RECOVERY SIMPLE WITH NO_WAIT
GO
DBCC SHRINKFILE (N‘dbname_log‘ , 0, TRUNCATEONLY)
GO
DBCC SHRINKDATABASE(N‘dbname‘ )
GO

日志大小还是一样。

技术分享图片
技术分享图片
 
DBCC OPENTRAN 查看是否打开的事务。发现有打开的事务,执行检查点再收缩,还是不行!
DBCC OPENTRAN (dbname) 
CHECKPOINT

技术分享图片

参考:http://bbs.csdn.net/topics/350199751,将日志事务标志为已分发,再收缩,不行!

--日志中所有复制的事务将标记为已分发
EXEC sp_repldone @xactid = NULL,@xact_segno = NULL,@numtrans = 0,@time = 0,@reset = 1

技术分享图片  

现在查看虚拟日志文件,发现有很多,并且都处于活动状态

dbcc loginfo

技术分享图片 

最重要的语句竟然忘了,这可以查看日志空间的重复使用正在等待最后一个检查点的描述.。发现是REPLICATION

SELECT name,log_reuse_wait_desc FROM sys.databases where name=‘dbname‘

技术分享图片

这个数据库之前有作为事物同步过,但是都删除了。分发库也不存在了,现在竟然还有日志在等待?!

参考http://bbs.csdn.net/topics/390674731?page=1 ,执行删除所有复制对象。

--删除当前数据库中所有复制对象
EXEC sp_removedbreplication dbname

再看日志重用状态,正常了!看来有效!

技术分享图片

在收缩数据库,查看已经收缩了!其他也恢复正常!
DBCC SHRINKFILE (N‘dbname_log‘ , 0, TRUNCATEONLY)
GO
DBCC LOGINFO
GO
DBCC OPENTRAN (dbname) 
GO

技术分享图片

此收缩方法,适用于发布过数据库订阅同步的情况,一般正常情况下,都可以收缩日志。

转自:https://blog.csdn.net/kk185800961/article/details/41865073

 




以上是关于SqlServer 数据库日志无法收缩处理过程的主要内容,如果未能解决你的问题,请参考以下文章

SQL server数据库日志满了怎么处理?

SQL server数据库日志满了怎么处理?

sqlserver 数据库日志收缩失败解决办法

SQL server2008无法收缩日志

如何收缩 SQL Server 中的 Tempdb 数据库

sql2005查询为何提示满,收缩数据库和文件不管用