今天按常用方法收缩一个测试用的数据库日志,发现没法收缩!
日志大小还是一样。
DBCC OPENTRAN 查看是否打开的事务。发现有打开的事务,执行检查点再收缩,还是不行!
将日志事务标志为已分发,再收缩,不行!
现在查看虚拟日志文件,发现有很多,并且都处于活动状态
最重要的语句竟然忘了,这可以查看日志空间的重复使用正在等待最后一个检查点的描述.。发现是REPLICATION
这个数据库之前有作为事物同步过,但是都删除了。分发库也不存在了,现在竟然还有日志在等待?!
执行删除所有复制对象。
再看日志重用状态,正常了!看来有效!
在收缩数据库,查看已经收缩了!其他也恢复正常!
=======================================================================
其他类似问题
=======================================================================
更改字段,出现错误(数据库是从一个发布库中备份还原过来的)
Caution: Changing any part of an object name could break scripts and stored procedures.
Msg 4928, Level 16, State 1, Procedure sp_rename, Line 547
Cannot alter column 'userid' because it is 'REPLICATED'.
Msg 0, Level 20, State 0, Line 0
当前命令发生了严重错误。应放弃任何可能产生的结果。
解决: