我将XML存储在nvarchar(max)字段中。我意识到有一个XML数据类型,但是在这种情况下,它不是那样存储的。假设XML的结构如下:
<root>
<hdr>
<name>aj</name>
</hdr>
<dtls>
<dtl>
<price>1</price>
</dtl>
<dtl>
<price>7</price>
</dtl>
<dtl>
<price>3</price>
</dtl>
</dtls>
</root>
我想做的是获取要记录的明细(dtl)节点的数量。我敢肯定这可以用xpath / xquery来实现,我只是不确定如何做到。
最佳答案
试试这个:
SELECT CAST(<YOUR_XML_COLUMN> AS XML).query('count(//dtl)')
FROM <YOUR_TABLE>
例如:
DECLARE @x NVARCHAR(MAX)
SET @x = '<root> <hdr> <name>aj</name> </hdr> <dtls> <dtl> <price>1</price> </dtl> <dtl> <price>7</price> </dtl> <dtl> <price>3</price> </dtl> </dtls> </root>'
SELECT CAST(@x AS XML).query('count(//dtl)')