3

库存 ELMAH_Error 表使用 nText 字段来存储错误条目。我发现通过添加 XML 类型的字段;然后将此新字段添加到填充该字段的 SPROC 的 INSERT 语句中;我可以更好地利用 ELMAH 的输出。

现在我想了解如何查询该 XML 字段中的特定元素值。该文件的结构如下:

<error [...]>
  <serverVariables>
    <item name="ALL_HTTP">
      <value string="..." />
    </item>
    <item name="ALL_RAW">
      <value string="..." />
    </item>
    .
    .
    .
  </serverVariables>
</error>

我需要能够查询下面特定项目的值。

因此,我正在查看15seconds.com文章中的一个示例:

SELECT MyXml.value('(/root/product[@id="304"]/name)[1]', 'nvarchar(30)')

并试图将这些值映射到我的字段结构 - 但不能。例如

select top 10 RealXML.value('(/error/serverVariables[@id="REMOTE_HOST"]/name)[0]', 'nvarchar(30)') 

其中 REMOTE_HOST 的格式为:

<item name="REMOTE_HOST">
  <value string="55.55.55.55" />
</item>

非常感激

4

1 回答 1

5

这应该有效:

select top 10 RealXML.value('(/error/serverVariables/item[@name="REMOTE_HOST"]/value/@string)[1]', 'nvarchar(30)') 

使用以下测试:

DECLARE @xml XML  = '
<error>
  <serverVariables>
    <item name="ALL_HTTP">
      <value string="..." />
    </item>
    <item name="ALL_RAW">
      <value string="..." />
    </item>
<item name="REMOTE_HOST">
  <value string="55.55.55.55" />
</item>
  </serverVariables>
</error>
'
SELECT @xml.value('(/error/serverVariables/item[@name="REMOTE_HOST"]/value/@string)[1]','nvarchar(30)') 
于 2010-11-18T12:55:09.360 回答