select filename from [TestDB1].dbo.sysfiles
select * from sys.databases where name = 'TestDB1'
--1).数据库是否开启自动收缩
SELECT is_auto_shrink_on, * FROM sys.databases
--2).维护计划/作业
SELECT job_id,* FROM msdb.dbo.sysjobsteps WHERE command LIKE '%shrink%'
SELECT * FROM msdb.dbo.sysjobs WHERE job_id='3A257CC0-FA1E-4D67-91DD-FF9F31B061E1'
select COUNT(*) from sys.databases --包括4个系统数据库和2个报表数据库
select * from sys.databases
注意:高危操作,注意识别连接实例和做好数据库备份!
之前客户场景,备份端连接的生产端实例,导致在备端SQL Server管理器里面直接误删除了生产端的数据库,所以执行该操作之前一定确认清楚,最好做一次全备,再执行删除。
declare @sql varchar(8000)
declare @dbname varchar(100)
--查询用户数据库(过滤掉master、msdb、ReportServer等系统数据库),创建游标
declare cur_my cursor for select name from sys.databases where database_id not in (1,2,3,4, 5, 6)
--打开游标
open cur_my
fetch next from cur_my into @dbname
--循环,直到游标为空
while @@FETCH_STATUS=0
--删除数据库
begin
set @sql='drop database '+ @dbname
--print (@sql)
exec (@sql)
fetch next from cur_my into @dbname
end
--关闭游标
close cur_my
--释放游标资源
deallocate cur_my
--收缩数据库
declare @DBname nvarchar(255), @logname varchar(255), @shrinksql varchar(8000)
set @DBname = ''
set @logname = @DBname + '_log'
set @shrinksql =
'USE [master]
ALTER DATABASE ' + @DBname + ' SET RECOVERY SIMPLE WITH NO_WAIT
ALTER DATABASE ' + @DBname + ' SET TORN_PAGE_DETECTION ON WITH NO_WAIT
ALTER DATABASE ' + @DBname + ' SET RECOVERY SIMPLE
ALTER DATABASE ' + @DBname + ' SET TORN_PAGE_DETECTION ON
USE ' + @DBname +
--如果引号里面还有引号,里面的引号需要用两个引号进行转义,即表示为''
' DBCC SHRINKFILE(N''' + @logname + ''', 10)
USE [master]
ALTER DATABASE ' + @DBname + ' SET RECOVERY FULL WITH NO_WAIT
ALTER DATABASE ' + @DBname + ' SET TORN_PAGE_DETECTION ON WITH NO_WAIT
ALTER DATABASE ' + @DBname + ' SET RECOVERY FULL
ALTER DATABASE ' + @DBname + ' SET TORN_PAGE_DETECTION ON'
--print @shrinksql
exec (@shrinksql)
以TestDB1为例,执行语句如下:
--查询收缩进度
declare @DBname nvarchar(255)
set @DBname = ''
SELECT T.text, R.Status, R.Command, DatabaseName = db_name(R.database_id),
R.percent_complete
from sys.dm_exec_requests R
cross apply sys.dm_exec_sql_text(R.sql_handle) T
WHERE db_name(R.database_id)=@DBname
AND T.text LIKE '%DBCC%'
GO
(1)设置为当用户模式:
ALTER DATABASE TestDB1 SET SINGLE_USER WITH ROLLBACK IMMEDIATE
立即回滚所有未完成事务,并将数据库设置为单用户模式。
有时候数据库在占用时,想做一些操作,无法操作。可以尝试将数据库切换为单用户模式来操作,操作完之后再切换回多用户模式即可。
(2)设置为多用户模式
ALTER DATABASE TestDB1 SET MULTI_USER
ALTER DATABASE TestDB1 SET RECOVERY FULL WITH NO_WAIT
设置为简单恢复模式
ALTER DATABASE TestDB1 SET RECOVERY SIMPLE WITH NO_WAIT
--第一次查询时,需要使用DBCC TRACEON打开数据页跟踪标记
DBCC TRACEON (3604);
--数据库名|数据库ID,1,页ID(十进制),3
dbcc page('testdb1', 1, 51,3)
select * from fn_dblog(NULL, NULL)