程序防止SqlServer使用SqlServer Profiler跟踪

大体思路:

1、使用默认函数(fn_trace_getinfo)查询跟踪列表;

2、调用系统存储过程(sp_trace_setstatus)修改跟踪状态。

相关Sql 语句:

declare @default_trace_id sql_variant

--查询数据库默认跟踪id
select @default_trace_id = value from sys.configurations where configuration_id = 1568

--查询数据库跟踪列表
--官方说明:https://docs.microsoft.com/zh-cn/sql/relational-databases/system-functions/sys-fn-trace-getinfo-transact-sql
SELECT distinct traceid FROM sys.fn_trace_getinfo(0)
where traceid <> @default_trace_id; 
GO  

--修改跟踪的状态
--官方说明:https://docs.microsoft.com/zh-cn/sql/relational-databases/system-stored-procedures/sp-trace-setstatus-transact-sql
--参数说明:trace_id(要修改跟踪的ID),status(状态)
--第二个参数值的枚举及说明
----0	停止指定的跟踪。
----1	启动指定的跟踪。
----2	关闭指定的跟踪并从服务器中删除其定义。
EXEC  sp_trace_setstatus 2, 0
GO




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值