我正在使用扩展事件设置警报,在该事件中,我以XML格式提取信息,因此我被困在从XML中查找值-对象名。
SELECT CAST(data AS XML) AS [result]
FROM #temp
WHERE data LIKE '%<text>Abort</text>%'
使用此查询,我已经提取了那些以XML格式超时的记录,并且通过此xml,我们需要使用T-SQL <value>XYZ</value></data>
将 XYZ 值作为对象名称。
上述选择查询的输出:
<event name="rpc_completed" package="sqlserver" timestamp="2019-02-20T14:42:39.678Z"><data name="cpu_time"><value>15000</value></data><data name="duration"><value>29999325</value></data><data name="physical_reads"><value>0</value></data><data name="logical_reads"><value>363</value></data><data name="writes"><value>0</value></data><data name="result"><value>2</value><text>Abort</text></data><data name="row_count"><value>9</value></data><data name="connection_reset_option"><value>0</value><text>None</text></data><data name="object_name"><value>XYZ</value></data><data name="statement"><value>exec XYZ </value></data><data name="data_stream"><value /></data><data name="output_parameters"><value /></data><action name="transaction_id" package="sqlserver"><value>0</value></action><action name="session_id" package="sqlserver"><value>1381</value></action><action name="server_principal_name" package="sqlserver"><value>sq</value></action><action name="database_name" package="sqlserver"><value>PR</value></action><action name="database_id" package="sqlserver"><value>5</value></action><action name="client_pid" package="sqlserver"><value>32048</value></action><action name="client_hostname" package="sqlserver"><value>RuntimeHost</value></action><action name="client_app_name" package="sqlserver"><value>test</value></action><action name="event_sequence" package="package0"><value>133050</value></action></event>
NA
输出应如下所示:
Object Name
XYZ
答案 0 :(得分:1)
您可以使用nodes
通过属性值过滤xml中的项目,然后使用value
提取所需的数据:
;with x as(
SELECT CAST(data AS XML) AS [result]
FROM #temp
WHERE data LIKE '%<text>Abort</text>%'
)
select
t.s.value('.', 'nvarchar(max)') as object_name
from
x
cross apply
[result].nodes('//data[@name = "object_name"]/value') t(s)
结果:
编辑
一种检索database_name
的方法是在nodes
标签上添加另一个action
过滤。要获取timestamp
,您只需在value
子句中添加一个select
,指定正确的xpath表达式即可:
;with x as(
SELECT CAST(data AS XML) AS [result]
FROM #temp
WHERE data LIKE '%<text>Abort</text>%'
)
select
t.s.value('.', 'nvarchar(max)') as [object_name]
, u.s.value('.', 'nvarchar(max)') as [database_name]
, [result].value('(/event/@timestamp)[1]', 'nvarchar(max)') as [timestamp]
from
x
cross apply
[result].nodes('//data[@name = "object_name"]/value') t(s)
cross apply
[result].nodes('//action[@name = "database_name"]/value') u(s)
结果为database_name
和timestamp
: