[英]Selecting XML Data from SQL query - No values returned
Xml Column returns no rows. Xml列不返回任何行。
Below created a table type and xml value inserted into that table. 下面创建了一个表类型和插入该表的xml值。 After executing the below mentioned two queries no value is returned.
执行以下提到的两个查询后,将不返回任何值。
Xml data is a valid data. xml数据是有效数据。
DECLARE @Test TABLE (Id INT IDENTITY (1,1), XMLDATA XML)
INSERT INTO @test
SELECT '
<TXLife xmlns="http://ACORD.org/Standards/Life/2" xmlns:tx="http://ACORD.org/Standards/Life/2" Version="2.20.00">
<TXLifeRequest PrimaryObjectID="Holding_1">
<CorrelationGUID>4b30545a-158b-441a-a37a-0b259f757059</CorrelationGUID>
</TXLifeRequest>
</TXLife>'
SELECT
Id
, XMLDATA.query('//CorrelationGUID') AS 'TransType'
, XMLDATA
FROM @test
SELECT C.value('./CorrelationGUID[1]', 'varchar(50)') AS 'TransType'
FROM @test
CROSS APPLY XMLDATA.nodes('/TXLife/TXLifeRequest') n (C)
Try this one - 试试这个-
DECLARE @XML XML
SELECT @XML = '
<TXLife xmlns="http://ACORD.org/Standards/Life/2" xmlns:tx="http://ACORD.org/Standards/Life/2" Version="2.20.00">
<TXLifeRequest PrimaryObjectID="Holding_1">
<CorrelationGUID>4b30545a-158b-441a-a37a-0b259f757059</CorrelationGUID>
</TXLifeRequest>
</TXLife>'
;WITH XMLNAMESPACES (DEFAULT 'http://ACORD.org/Standards/Life/2')
SELECT t.c.value('CorrelationGUID[1]', 'UNIQUEIDENTIFIER')
FROM @XML.nodes('//TXLifeRequest') t(c)
Output - 输出-
------------------------------------
4B30545A-158B-441A-A37A-0B259F757059
Well, if I test your code with CREATE TABLE
, here and here , the unfiltered select works just fine. 好吧,如果我在此处和此处使用
CREATE TABLE
测试您的代码,则未经过滤的选择效果很好。 However, the second filtered select returns no results. 但是,第二个筛选的选择不返回任何结果。
If I alter the query to to specify the right namespace, like in @Devart 's answer, 如果我更改查询以指定正确的名称空间,例如@Devart的答案,
WITH XMLNAMESPACES (DEFAULT 'http://ACORD.org/Standards/Life/2')
SELECT
C.value('./CorrelationGUID[1]', 'varchar(50)') AS 'TransType'
FROM
Test
CROSS APPLY
XMLDATA.nodes('/TXLife/TXLifeRequest') n (C)
You can see, it works as expected . 您可以看到, 它按预期工作 。
You need to declare the namespace. 您需要声明名称空间。 Try this:
尝试这个:
SELECT
XMLDATA.value('declare namespace L="http://ACORD.org/Standards/Life/2";(//L:CorrelationGUID)[1]',
'UNIQUEIDENTIFIER') AS 'TransType'
FROM @test
UNION ALL
SELECT
C.value('declare namespace L="http://ACORD.org/Standards/Life/2";(./L:CorrelationGUID)[1]',
'UNIQUEIDENTIFIER') AS 'TransType'
FROM @test
CROSS APPLY
XMLDATA.nodes('declare namespace L="http://ACORD.org/Standards/Life/2";/L:TXLife/L:TXLifeRequest') N(C)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.