SQL Server运维常用语句

1、查询数据文件和日志文件路径
select filename from [TestDB1].dbo.sysfiles

 

2、查询数据基本信息,包括数据库ID、创建日期、恢复模式、是否收缩等
select * from sys.databases where name = 'TestDB1'

 

3、查询收缩计划
--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'

 

4、查询实例下的数据库总数量
select COUNT(*) from sys.databases    --包括4个系统数据库和2个报表数据库

select *  from sys.databases

 

5、删除实例下的所有数据库
注意:高危操作,注意识别连接实例和做好数据库备份!

之前客户场景,备份端连接的生产端实例,导致在备端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
 

6、收缩数据库
--收缩数据库
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为例,执行语句如下:

7、查询收缩进度
--查询收缩进度
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
 

8、设置用户模式
(1)设置为当用户模式:

ALTER DATABASE TestDB1 SET SINGLE_USER WITH ROLLBACK IMMEDIATE

立即回滚所有未完成事务,并将数据库设置为单用户模式。

有时候数据库在占用时,想做一些操作,无法操作。可以尝试将数据库切换为单用户模式来操作,操作完之后再切换回多用户模式即可。

(2)设置为多用户模式
ALTER DATABASE TestDB1 SET MULTI_USER

 

9、设置为完整恢复模式
ALTER DATABASE TestDB1 SET RECOVERY FULL WITH NO_WAIT

设置为简单恢复模式

ALTER DATABASE TestDB1 SET RECOVERY SIMPLE WITH NO_WAIT

 

10、查询页数据
--第一次查询时,需要使用DBCC TRACEON打开数据页跟踪标记
 
DBCC TRACEON (3604);
 
--数据库名|数据库ID,1,页ID(十进制),3
dbcc page('testdb1', 1, 51,3)  
 

11、查询活动日志
select * from fn_dblog(NULL, NULL)
--------------------- 
作者:rammuschow 
来源:CSDN 
原文:https://blog.csdn.net/rammuschow/article/details/81663525 
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值