濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL Server無法收縮日志文件的原因分析及解決辦法

SQL Server無法收縮日志文件的原因分析及解決辦法

熱門標(biāo)簽:地圖標(biāo)注可以編輯地名嗎 真3地圖標(biāo)注 臺灣外呼系統(tǒng)軟件 地圖標(biāo)注跑線下市場 樂昌電話機(jī)器人 疫情時期電話機(jī)器人 南京怎么申請400這種電話 南通智能外呼系統(tǒng)怎么樣 濮陽清豐400開頭的電話申請

最近服務(wù)器執(zhí)行收縮日志文件大小的job老是報錯

我所用的一個批量收縮日志腳本

USE [master]
GO
/****** Object: StoredProcedure [dbo].[ShrinkUser_DATABASESLogFile] Script Date: 01/05/2016 09:52:39 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROC [dbo].[ShrinkUser_DATABASESLogFile]
AS
BEGIN
 DECLARE @DBNAME NVARCHAR(MAX)
DECLARE @SQL NVARCHAR(MAX)
--臨時表保存數(shù)據(jù)
CREATE TABLE #DataBaseServerData
(
 ID INT IDENTITY(1, 1) ,
 DBNAME NVARCHAR(MAX) ,
 Log_Total_MB DECIMAL(18, 1) NOT NULL ,
 Log_FREE_SPACE_MB DECIMAL(18, 1) NOT NULL 
)
--游標(biāo)
DECLARE @itemCur CURSOR
SET 
@itemCur = CURSOR FOR 
SELECT name from SYS.[databases] WHERE [name] NOT IN ('MASTER','MODEL','TEMPDB','MSDB','ReportServer','ReportServerTempDB','distribution')
and state=0
OPEN @itemCur
FETCH NEXT FROM @itemCur INTO @DBNAME
WHILE @@FETCH_STATUS = 0
 BEGIN
 SET @SQL=N'USE ['+@DBNAME+'];'+CHAR(10)
 +'
  DECLARE @TotalLogSpace DECIMAL(18, 1)
  DECLARE @FreeLogSpace DECIMAL(18, 1)
  DECLARE @filename NVARCHAR(MAX)
  DECLARE @CanshrinkSize BIGINT
  DECLARE @SQL1 nvarchar(MAX)
SELECT @TotalLogSpace=(SUM(CONVERT(dec(17, 2), sysfiles.size)) / 128) 
  FROM dbo.sysfiles AS sysfiles WHERE [groupid]=0
SELECT @FreeLogSpace = ( SUM(( size - FILEPROPERTY(name, ''SpaceUsed'') )) )/ 128.0
  FROM sys.database_files
  WHERE [type] = 1
SELECT @filename=name FROM sys.database_files WHERE [type]=1
SET @CanshrinkSize=CAST((@TotalLogSpace-@FreeLogSpace) AS BIGINT)
 SET @SQL1 = ''USE ['+@DBNAME+']''
SET @SQL1 = @SQL1+
 ''DBCC SHRINKFILE (['' + @filename + ''],'' + CAST(@CanshrinkSize+1 AS NVARCHAR(MAX)) + '')''
 EXEC (@SQL1)'
 EXEC (@SQL)
  FETCH NEXT FROM @itemCur INTO @DBNAME
 END 
CLOSE @itemCur
DEALLOCATE @itemCur
SELECT * FROM [#DataBaseServerData]
DROP TABLE [#DataBaseServerData]
END 

幸虧報錯信息還是很全面,根據(jù)報錯信息找到相關(guān)的數(shù)據(jù)庫,執(zhí)行一下DBCC LOGINFO

dbcc loginfo(N'cdb')

發(fā)現(xiàn)確實(shí)只有兩個VLF文件,不能再收縮了,因?yàn)槭桥磕_本,當(dāng)其中有一個庫失敗之后,后續(xù)的庫就不會再進(jìn)行收縮操作

這里只要加上數(shù)據(jù)庫的VLF數(shù)量的判斷就可以了

本文寫的不好,還請各位大俠提出寶貴意見,如有好的解決方案歡迎分享,大家共同學(xué)習(xí)進(jìn)步。

您可能感興趣的文章:
  • Sqlserver 2000/2005/2008 的收縮日志方法和清理日志方法
  • SQL SERVER 2008數(shù)據(jù)庫日志文件收縮的方法
  • SQL語句實(shí)現(xiàn)SQL Server 2000及Sql Server 2005日志收縮(批量)
  • SQL SERVER日志進(jìn)行收縮的圖文教程

標(biāo)簽:通遼 南京 廣安 阿里 馬鞍山 福建 河北 陜西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server無法收縮日志文件的原因分析及解決辦法》,本文關(guān)鍵詞  SQL,Server,無法,收縮,日志,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server無法收縮日志文件的原因分析及解決辦法》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server無法收縮日志文件的原因分析及解決辦法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    黔南| 禹州市| 贺兰县| 通辽市| 盘锦市| 嵊泗县| 古丈县| 铜鼓县| 怀来县| 保定市| 若尔盖县| 拜城县| 凤山县| 壤塘县| 尚志市| 江川县| 张家口市| 德令哈市| 怀化市| 延庆县| 南召县| 盘山县| 林西县| 孟州市| 明溪县| 扎囊县| 德昌县| 黄石市| 朝阳县| 长沙县| 泰和县| 诏安县| 黎城县| 临猗县| 清水河县| 锦屏县| 海门市| 双柏县| 塘沽区| 双流县| 和田县|