库存 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>
非常感激