top of page
Writer's pictureKunal Ranpura

Script to find No. of Virtual Log File Count (VLFs)

Updated: Jul 30, 2019

--Script to find number of VLF.


SET NOCOUNT ON;



/* declare variables required */


DECLARE @DatabaseId INT;


DECLARE @TSQL varchar(MAX);


DECLARE cur_DBs CURSOR FOR


SELECT database_id FROM sys.databases;


OPEN cur_DBs;


FETCH NEXT FROM cur_DBs INTO @DatabaseId



--These table variables will be used to store the data


DECLARE @tblAllDBs Table (DBName sysname


, FileId INT


, FileSize BIGINT


, StartOffset BIGINT


, FSeqNo INT


, Status TinyInt


, Parity INT


, CreateLSN NUMERIC(25,0)


)


IF '11' = substring(convert(char(12),serverproperty('productversion')), 1, 2)


BEGIN


DECLARE @tblVLFs2012 Table (RecoveryUnitId BIGINT


, FileId INT


, FileSize BIGINT


, StartOffset BIGINT


, FSeqNo INT


, Status TinyInt


, Parity INT


, CreateLSN NUMERIC(25,0)


);


END


ELSE


BEGIN


DECLARE @tblVLFs Table (


FileId INT


, FileSize BIGINT


, StartOffset BIGINT


, FSeqNo INT


, Status TinyInt


, Parity INT


, CreateLSN NUMERIC(25,0)


);


END



--loop through each database and get the info


WHILE @@FETCH_STATUS = 0


BEGIN



PRINT 'DB: ' + CONVERT(varchar(200), DB_NAME(@DatabaseId));


SET @TSQL = 'dbcc loginfo('+CONVERT(varchar(12), @DatabaseId)+');';



IF '11' = substring(convert(char(12),serverproperty('productversion')), 1, 2)


BEGIN


DELETE FROM @tblVLFs2012;


INSERT INTO @tblVLFs2012


EXEC(@TSQL);


INSERT INTO @tblAllDBs


SELECT DB_NAME(@DatabaseId)


, FileId


, FileSize


, StartOffset


, FSeqNo


, Status


, Parity


, CreateLSN


FROM @tblVLFs2012;


END


ELSE


BEGIN


DELETE FROM @tblVLFs;


INSERT INTO @tblVLFs


EXEC(@TSQL);


INSERT INTO @tblAllDBs


SELECT DB_NAME(@DatabaseId)


, FileId


, FileSize


, StartOffset


, FSeqNo


, Status


, Parity


, CreateLSN


FROM @tblVLFs;


END



FETCH NEXT FROM cur_DBs INTO @DatabaseId


END


CLOSE cur_DBs;


DEALLOCATE cur_DBs;



--just for formating if output to Text


PRINT '';


PRINT '';


PRINT '';



--Return the data based on what we have found


SELECT a.DBName


, COUNT(a.FileId) AS [TotalVLFs]


, MAX(b.[ActiveVLFs]) AS [ActiveVLFs]


, (SUM(a.FileSize) / COUNT(a.FileId) / 1024) AS [AvgFileSizeKb]


FROM @tblAllDBs a


INNER JOIN (


SELECT DBName


, COUNT(FileId) [ActiveVLFs]


FROM @tblAllDBs


WHERE Status = 2


GROUP BY DBName


) b


ON b.DBName = a.DBName


GROUP BY a.DBName


ORDER BY TotalVLFs DESC;




SET NOCOUNT OFF;


/*

During Database setup Log file should be pre-set to appropriate size to avoid too many VLFs. Also log file growth needs to be set to specific value to avoid too many log file growth. Having too many VLFs can slow down system performance including backups, recovery and OLTP operations.

*/


--Another Way of finding VLFs for current Database


DBCC LOGINFO;


-- Get VLF count for transaction log for the current database,

-- number of rows equals VLF count. Lower is better!


14 views0 comments

Recent Posts

See All

Comentários


bottom of page