当前位置:网站首页>Actual combat: sqlserver 2008 Extended event XML is converted to standard table format [easy to understand]
Actual combat: sqlserver 2008 Extended event XML is converted to standard table format [easy to understand]
2022-07-07 21:20:00 【Full stack programmer webmaster】
Hello everyone , I meet you again , I'm the king of the whole stack .
-- The hypothesis already exists Event Session Delete
IF EXISTS (SELECT * FROM sys.server_event_sessions WHERE name='MonitorLongQuery')
DROP EVENT SESSION MonitorLongQuery ON SERVER
GO
-- establish Extended Event session
CREATE EVENT SESSION MonitorLongQuery ON SERVER
-- add to Event(SQL Completion event )
ADD EVENT sqlserver.sql_statement_completed
(
-- Specify collected Event Information
ACTION
(
sqlserver.database_id,
sqlserver.session_id,
sqlserver.username,
sqlserver.client_hostname,
sqlserver.sql_text,
sqlserver.tsql_stack
)
--Filter Information (CPU Exceed or the whole execution time exceeds 10S)
WHERE sqlserver.sql_statement_completed.cpu> 10000
OR sqlserver.sql_statement_completed.duration> 10000
)
-- Specify collected Event Information storage location ( It can be stored in memory or in files )
ADD TARGET package0.asynchronous_file_target
(
SET FILENAME = N's:\monitor\LogQuery.xet',
METADATAFILE = 'S:\monitor\LongQuery.xem'
)
GO
SELECT sessions.name AS SessionName,sevents.package as PackageName,
sevents.name AS EventName,
sevents.predicate, sactions.name AS ActionName, stargets.name AS TargetName
FROM sys.server_event_sessions sessions
INNER JOIN sys.server_event_session_events sevents
ON sessions.event_session_id= sevents.event_session_id
INNER JOIN sys.server_event_session_actions sactions
ON sessions.event_session_id= sactions.event_session_id
INNER JOIN sys.server_event_session_targets stargets
ON sessions.event_session_id= stargets.event_session_id
WHERE sessions.name='MonitorLongQuery'
GO
-- start-up Event Session Capture data
ALTER EVENT SESSION MonitorLongQuery
ON SERVER STATE = START
GO
-- Inquire about
SELECT CAST(event_data AS XML) event_data,*
FROM sys.fn_xe_file_target_read_file
('s:\monitor\LogQuery_0_129954478780290000.xet',
's:\monitor\LongQuery_0_129954478780330000.xem',NULL,NULL)
go
- Stop Event Session
ALTER EVENT SESSION MonitorLongQuery
ON SERVER STATE = STOP
GO
-- Delete Event Session
IF EXISTS(SELECT * FROM sys.server_event_sessions WHERE name='MonitorLongQuery')
DROP EVENT SESSION MonitorLongQuery ON SERVER
GO
------------ take XML Convert to regular table format
IF EXISTS ( SELECT *
FROM tempdb.dbo.sysobjects
WHERE id = OBJECT_ID(N'tempdb..#MyData')
AND type = 'U' )
DROP TABLE #MyData
go
CREATE TABLE #MyData
(
database_id INT NOT NULL ,
username NVARCHAR(100) NOT NULL,
client_hostname NVARCHAR(100) NOT NULL,
sql_text NVARCHAR(MAX) NOT NULL ,
cpu INT NOT NULL
)
go
DECLARE @xmlData XML
DECLARE @xmlString NVARCHAR(MAX)
DECLARE @database_id INT
DECLARE @username NVARCHAR(100)
DECLARE @client_hostname NVARCHAR(100)
DECLARE @sql_text NVARCHAR(MAX)
DECLARE @cpu INT
DECLARE myCur CURSOR READ_ONLY
FOR
SELECT TOP 200 event_data --CAST(event_data AS XML)
FROM sys.fn_xe_file_target_read_file
('s:\monitor\LogQuery_0_130638808366940000.xet',
's:\monitor\LongQuery_0_130638808366940000.xem',NULL,NULL)
OPEN myCur
FETCH NEXT FROM myCur INTO @xmlString
WHILE @@FETCH_STATUS = 0
BEGIN
BEGIN TRY
SET @xmlData = CAST(@xmlString AS XML)
--set @cpu = 0
-- obtain cpu
SET @cpu = @xmlData.query('//data[@name="cpu"]/value').value('(value)[1]',
'INT')
-- obtain database_id
SET @database_id = @xmlData.query('//action[@name="database_id"]/value').value('(value)[1]',
'INT')
-- obtain username
SET @username = @xmlData.query('//action[@name="username"]/value').value('(value)[1]',
'NVARCHAR(100)')
-- obtain hostname
SET @client_hostname = @xmlData.query('//action[@name="client_hostname"]/value').value('(value)[1]',
'NVARCHAR(100)')
-- obtain sql_text
SET @sql_text = @xmlData.query('//action[@name="sql_text"]/value').value('(value)[1]',
'NVARCHAR(MAX)')
-- Start inserting data
INSERT #MyData
( database_id,
sql_text,
username,
client_hostname,
cpu )
VALUES ( @database_id, -- database_id - int
@sql_text, -- sql_text - nvarchar(max)
@username,
@client_hostname,
@cpu
)
END TRY
BEGIN CATCH
END CATCH
FETCH NEXT FROM myCur INTO @xmlString
END
CLOSE myCur
DEALLOCATE myCur
SELECT b.name,a.username,a.client_hostname,a.sql_text,a.cpu FROM #MyData AS a
inner join sys.databases as b
on a.database_id=b.database_id
order by a.cpu desc
goPublisher : Full stack programmer stack length , Reprint please indicate the source :https://javaforall.cn/116529.html Link to the original text :https://javaforall.cn
边栏推荐
- 2022年在启牛开中银股票的账户安全吗?
- Mysql子查询关键字的使用方式(exists)
- FatMouse' Trade(杭电1009)
- EasyUI date control emptying value
- Using enumeration to realize English to braille
- CodeSonar如何帮助无人机查找软件缺陷?
- The difference between NPM uninstall and RM direct deletion
- I have to use my ID card to open an account. Is the bank card safe? I don't understand it
- Demon daddy C
- 95年专注安全这一件事 沃尔沃未来聚焦智能驾驶与电气化领域安全
猜你喜欢

使用枚举实现英文转盲文

Intelligent software analysis platform embold

The little money made by the program ape is a P!

Tensorflow2. How to run under x 1 Code of X

Ten thousand word summary data storage, three knowledge points

Onespin | solve the problems of hardware Trojan horse and security trust in IC Design

How to meet the dual needs of security and confidentiality of medical devices?

程序猿赚的那点钱算个P啊!

C language helps you understand pointers from multiple perspectives (1. Character pointers 2. Array pointers and pointer arrays, array parameter passing and pointer parameter passing 3. Function point
Codesonar enhances software reliability through innovative static analysis
随机推荐
Referrer和Referrer-Policy简介
恶魔奶爸 指南帖——简易版
Make this crmeb single merchant wechat mall system popular, so easy to use!
easyui 日期控件清空值
Data sorting in string
How can big state-owned banks break the anti fraud dilemma?
恶魔奶爸 A1 语音听力初挑战
Implement secondary index with Gaussian redis
Implementation of mahout Pearson correlation
[function recursion] do you know all five classic examples of simple recursion?
[uvalive 6663 count the regions] (DFS + discretization) [easy to understand]
特征生成
guava多线程,futurecallback线程调用不平均
Demon daddy A1 speech listening initial challenge
目标:不排斥 yaml 语法。争取快速上手
浅解ARC中的 __bridge、__bridge_retained和__bridge_transfer
Deployment, recall and deletion solutions - stsadm and PowerShell "suggestions collection"
gridView自己定义做时间排版「建议收藏」
阿里云有奖体验:如何通过ECS挂载NAS文件系统
Do you have to make money in the account to open an account? Is the fund safe?