MS SQL
May 2, 2023
Как получить и изменить режим восстановления (Recovery model) баз данных SQL Server
Получить режим восстановления для всех баз данных:
SELECT name,recovery_model_desc AS Recovery_model FROM sys.databases ORDER BY recovery_model_desc, name
Другой вариант получить режим восстановления для всех баз данных, за исключением системных:
SELECT [name], DATABASEPROPERTYEX([name],'recovery') AS Recovery_model
FROM sysdatabases
WHERE name not in ('master','model','tempdb','msdb')
ORDER BY Recovery_model, nameКак изменить режим восстановления на SIMPLE для всех баз дынных, за исключением системных:
USE MASTER
declare
@isql varchar(2000),
@dbname varchar(64),
@logfile varchar(128)
declare c1 cursor for
SELECT d.name, mf.name as logfile
FROM sys.master_files mf
inner join sys.databases d
on mf.database_id = d.database_id
where recovery_model_desc <> 'SIMPLE'
and d.name not in ('master','model','msdb','tempdb')
and mf.type_desc = 'LOG'
open c1
fetch next from c1 into @dbname, @logfile
While @@fetch_status <> -1
begin
select @isql = 'ALTER DATABASE [' + @dbname + '] SET RECOVERY SIMPLE'
print @isql
exec(@isql)
select @isql='USE [' + @dbname + '] checkpoint'
print @isql
exec(@isql)
select @isql='USE [' + @dbname + '] DBCC SHRINKFILE ([' + @logfile + '], 1)'
print @isql
exec(@isql)
fetch next from c1 into @dbname, @logfile
end
close c1
deallocate c1