![](/img/trans.png)
[英]Find and specific pattern and extract data from a column having string values
[英]How to extract values with a specific data from an XML column?
我有一個查詢,給出了一個錯誤,我不知道為什么會給出該錯誤。 問題是什么?
SELECT top 10 [ID]
,[EVENTCLASS]
,[EVENTNAME]
,[EVENTDATA]
,[EVENTDATE]
,[BYUSER]
,[IDENTIFIER]
,[ZONE]
,[ARCHIVED]
, metadata.value('(./@Value)[1]', 'nvarchar(max)') as CurrentEvent
FROM [dbo].[EventLog] with(nolock)
cross apply eventdata.nodes ('/document/data[@name = ''EventStatus'']') as metadata
where convert (date, eventdate) > '2019-04-15'
and metadata.value('(./@value)[1]', 'nvarchar(max)') = 'Recognized'
我必須在Eventdata列中進行搜索,該列是這樣的XML:
<Document ID="50f1c559-7a2a-4420-8fcb-de1e3d523c1a" Action="CREATE">
<Data Name="EventTenant" Value="soc" Type="System.String" />
<Data Name="TargetTenant" Value="soc" Type="System.String" />
<Data Name="UserId" Value="519" Type="System.Int32" />
<Data Name="EventStatus" Value="Recognized" Type="System.String" />
<Data Name="TimeStamp" Value="2019-03-15 12:22:02.095" Type="System.String" />
<Data Name="NextEventStatus" Value="Exported" Type="System.String" />
<Data Name="NextEventAppId" Value="003" Type="System.String" />
<Data Name="DocumentId" Value="50f1c559-7a2a-4420-8fcb-de1e3d523c1a,003" Type="System.String" />
</Document>
我想按EventStatus及其值進行搜索。
您正在粉碎Name=EventStatus
節點,並使用Value=Recognized
的where子句。
這些可以合並成一個使用存在這樣的事情。
SELECT top 10 [ID]
,[EVENTCLASS]
,[EVENTNAME]
,[EVENTDATA]
,[EVENTDATE]
,[BYUSER]
,[IDENTIFIER]
,[ZONE]
,[ARCHIVED]
FROM [dbo].[EventLog]
where convert (date, eventdate) > '2019-04-15'
and eventdata.exist('/Document/Data[@Name = "EventStatus" and @Value = "Recognized"]') = 1
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.