在字典中查找下一个标记

时间:2017-02-14 15:49:25

标签: sql-server dictionary xquery xquery-sql

我在SQL Server表中有一个XML字段,我需要知道在我的表中是否已经使用了具有给定键和给定值的键值/值。

所以这是我的桌子(简化) dbo.mytable:
primaryKey,INT
xml_data,NOT NULL

xml_data字段的特征是以下XSN:

<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified">
    <xsd:element name="a">
        <xsd:complexType>
            <xsd:complexContent>
                <xsd:restriction base="xsd:anyType">
                    <xsd:sequence>
                        <xsd:element name="b" type="NonEmptyString" />
                        <xsd:element name="c" type="NonEmptyString" />
                        <xsd:element name="d" type="NonEmptyString" />
                        <xsd:element name="e" type="xsd:dateTime" />
                        <xsd:element name="dict">
                            <xsd:complexType>
                                <xsd:complexContent>
                                    <xsd:restriction base="xsd:anyType">
                                        <xsd:choice maxOccurs="unbounded">
                                            <xsd:sequence>
                                                <xsd:element name="key" type="NonEmptyString" />
                                                <xsd:element name="value" type="xsd:string" />
                                            </xsd:sequence>
                                        </xsd:choice>
                                    </xsd:restriction>
                                </xsd:complexContent>
                            </xsd:complexType>
                        </xsd:element>
                    </xsd:sequence>
                    <xsd:attribute name="version" type="xsd:float" />
                </xsd:restriction>
            </xsd:complexContent>
        </xsd:complexType>
    </xsd:element>
    <xsd:simpleType name="NonEmptyString">
        <xsd:restriction base="xsd:string">
            <xsd:minLength value="1" />
        </xsd:restriction>
    </xsd:simpleType>
</xsd:schema>

对于这个给定的XML(例如):

<a>
    <b>Value</b>
    <c>Value</c>
    <d>Value</d>
    <e>2017-02-14T00:00:00</e>
    <dict>
        <key>myKey</key>
        <value>myValue</value>
        <key>anotherKey</key>
        <value>myValue</value>
    </dict>
</a>

我需要知道表中是否包含第一个键“myKey”的值“myValue”。

我想我可以使用[xml_data].exist()函数,但是我有关于如何形成XQuery的问题。

我开始编写以下XQuery:
for $key in /a/dict/key where data($key) = ''myKey'' return $key
但我无法找到,如何获得以下标签。

这可能会给“低估”提供类似的东西:

SELECT [xml_data].exist('
for $key 
in /a/dict/key 
where data($key) = ''myKey'' 
return $key.followingTag == ''myValue''
') FROM dbo.mytable;

参考文献: https://msdn.microsoft.com/en-us/library/ms189869.aspx

1 个答案:

答案 0 :(得分:1)

考虑以下答案:https://stackoverflow.com/a/19253986/3635715
以下文档:https://msdn.microsoft.com/en-us/library/ms178030.aspx

这是我的问题的XQuery:
data(/a/dict/value[. >> (/a/dict/key[. = "myKey"])[1]])[1]

以下是我的问题的答案:

SELECT COUNT(primaryKey) FROM dbo.mytable
WHERE [xml_data].value('
 data(/a/dict/value[. >> (/a/dict/key[. = "myKey"])[1]])[1]
', 'varchar(max)') = 'myValue'

请注意,此答案仅适用于对应于&#34; myKey&#34;的第一个键。找到。
对我来说将是这样的。

同时考虑这个答案:https://stackoverflow.com/a/10408858/3635715
查询可以这样参数化:

DECLARE @key AS NVARCHAR(max)
DECLARE @value AS NVARCHAR(max)

SET @key = N'myKey'
SET @value = N'myValue'

SELECT COUNT(primaryKey) FROM dbo.mytable
WHERE [xml_data].value('
    data(/a/dict/value[. >> (/a/dict/key[. = sql:variable("@key")])[1]])[1]', 'varchar(max)
    ') = @value