![](/img/trans.png)
[英]Where clause on a SQL Server XML column filtering on attribute AND value
[英]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.