繁体   English   中英

XML 值的 SQL Server Where 子句路径

[英]SQL Server Where Clause Path for XML Value

主要问题是如何在 SQL for XML 中使用where子句。

我需要返回“团队”所在的 XML 行。

你可以在这里查看我的示例小提琴: http ://sqlfiddle.com/#!18/ de221e/2

桌子:

CREATE TABLE test
(
  id int,
  value xml
  )

  INSERT INTO test (id, value)
  VALUES 
  ('1', N'<?xml version="1.0" encoding="utf-16" standalone="yes"?> <Atts>
        <Att>
            <Name>test</Name>
        </Att>
                <Att>
            <Name>team</Name>
        </Att>
                <Att>
            <Name>test</Name>
        </Att>
        </Atts>'),
          ('2', N'<?xml version="1.0" encoding="utf-16" standalone="yes"?> <Atts>
        <Att>
            <Name>test</Name>
        </Att>
                <Att>
            <Name>test</Name>
        </Att>
                <Att>
            <Name>test</Name>
        </Att>
        </Atts>');

询问:

select * from test
where value.value('(/Atts/Att/Name)[1]','varchar(max)') = 'team'

这不会返回任何东西。

但是,如果您对出现在 XML 中的名字执行 where 子句,则它会起作用,例如

select * from test
where value.value('(/Atts/Att/Name)[1]','varchar(max)') = 'test'

返回:

| id |                                                                                             value |
|----|---------------------------------------------------------------------------------------------------|
|  1 | <Atts><Att><Name>test</Name></Att><Att><Name>team</Name></Att><Att><Name>test</Name></Att></Atts> |
|  2 | <Atts><Att><Name>test</Name></Att><Att><Name>test</Name></Att><Att><Name>test</Name></Att></Atts> |

预期结果是此查询应返回:

select * from test
where value.value('(/Atts/Att/Name)[1]','varchar(max)') = 'team'

| id |                                                                                             value |
|----|---------------------------------------------------------------------------------------------------|
|  1 | <Atts><Att><Name>test</Name></Att><Att><Name>team</Name></Att><Att><Name>test</Name></Att></Atts> |

如果“团队”出现在 XML 中但不在第一个中,我该如何返回它的任何想法

最好使用exist()方法。 无论其位置如何,它都会检查“团队”值。 exist() 方法(xml 数据类型)

SQL

select * from test
where value.exist('/Atts/Att/Name[./text()="team"]') = 1;

这是第二个。 你在看第一个。

这会给你你想要的结果

select * from test
where value.value('(/Atts/Att/Name)[2]','varchar(max)') = 'team'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM