xml - SQL Server 2008 查询 Soap XML

标签 xml sql-server-2008 t-sql soap

我一直在尝试使用 T-SQL 处理此 SOAP XML 返回,但我得到的只是 NULL 或什么也没有。我尝试了不同的方法并将它们全部粘贴在下面。

Declare @xmlMsg xml;

Set @xmlMsg = 
'<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <soap:Body>
    <SendWarrantyEmailResponse xmlns="http://Web.Services.Warranty/">
      <SendWarrantyEmailResult xmlns="http://Web.Services.SendWarrantyResult">
        <WarrantyNumber>120405000000015</WarrantyNumber>
        <Result>Cannot Send Email to anonymous account!</Result>
        <HasError>true</HasError>
        <MsgUtcTime>2012-06-07T01:11:36.8665126Z</MsgUtcTime>
      </SendWarrantyEmailResult>
    </SendWarrantyEmailResponse>
  </soap:Body>
</soap:Envelope>';

declare @table table (data xml);
insert into @table values (@xmlMsg);

select data from @table;

WITH xmlnamespaces ('http://schemas.xmlsoap.org/soap/envelope/' as [soap], 'http://Web.Services.Warranty' as SendWarrantyEmailResponse, 'http://Web.Services.SendWarrantyResult' as SendWarrantyEmailResult)
SELECT Data.value('(/soap:Envelope[1]/soap:Body[1]/SendWarrantyEmailResponse[1]/SendWarrantyEmailResult[1]/WarrantyNumber[1])[1]','VARCHAR(500)') AS WarrantyNumber
FROM @Table ;

;with xmlnamespaces('http://schemas.xmlsoap.org/soap/envelope/' as [soap],'http://Web.Services.Warranty' as SendWarrantyEmailResponse,'http://Web.Services.SendWarrantyResult' as SendWarrantyEmailResult)
--select @xmlMsg.value('(/soap:Envelope/soap:Body/SendWarrantyEmailResponse/SendWarrantyEmailResult/WarrantyNumber)[0]', 'nvarchar(max)')
--select T.N.value('.', 'nvarchar(max)') from @xmlMsg.nodes('/soap:Envelope/soap:Body/SendWarrantyEmailResponse/SendWarrantyEmailResult') as T(N)
select @xmlMsg.value('(/soap:Envelope/soap:Body/SendWarrantyEmailResponse/SendWarrantyEmailResult/HasError)[1]','bit') as test

;with xmlnamespaces('http://schemas.xmlsoap.org/soap/envelope/' as [soap],'http://Web.Services.Warranty' as [SendWarrantyEmailResponse],'http://Web.Services.SendWarrantyResult' as [SendWarrantyEmailResult])
SELECT
 SendWarrantyEmailResult.value('WarrantyNumber[1]','varchar(max)') AS WarrantyNumber,
 SendWarrantyEmailResult.value('Result[1]','varchar(max)') AS Result,
 SendWarrantyEmailResult.value('HasError[1]','bit') AS HasError,
 SendWarrantyEmailResult.value('MsgUtcTime[1]','datetime') AS MsgUtcTime
FROM @xmlMsg.nodes('/soap:Envelope/soap:Body/SendWarrantyEmailResponse/SendWarrantyEmailResult') SendWarrantyEmailResults(SendWarrantyEmailResult)

最佳答案

嗯,我花了一点时间重新思考,然后我想出了答案,所以我确信有人会在寻找这个。

仔细看看命名空间的缩写,它是使这一切发挥作用的魔力。希望这对那里的人有帮助

Declare @xmlMsg xml;

Set @xmlMsg = 
'<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <soap:Body>
    <SendWarrantyEmailResponse xmlns="http://Web.Services.Warranty/">
      <SendWarrantyEmailResult xmlns="http://Web.Services.SendWarrantyResult">
        <WarrantyNumber>120405000000015</WarrantyNumber>
        <Result>Cannot Send Email to anonymous account!</Result>
        <HasError>true</HasError>
        <MsgUtcTime>2012-06-07T01:11:36.8665126Z</MsgUtcTime>
      </SendWarrantyEmailResult>
    </SendWarrantyEmailResponse>
  </soap:Body>
</soap:Envelope>';

declare @table table (data xml);
insert into @table values (@xmlMsg);

select data from @table;

WITH xmlnamespaces (
'http://schemas.xmlsoap.org/soap/envelope/' as [soap], 
'http://Web.Services.Warranty/' as Resp, 
'http://Web.Services.SendWarrantyResult' as Res)
SELECT Data.value('(/soap:Envelope/soap:Body/Resp:SendWarrantyEmailResponse/Res:SendWarrantyEmailResult/Res:WarrantyNumber)[1]','VARCHAR(500)') AS WarrantyNumber
FROM @Table ;

;with xmlnamespaces(
'http://schemas.xmlsoap.org/soap/envelope/' as [soap],
'http://Web.Services.Warranty/' as Resp,
'http://Web.Services.SendWarrantyResult' as Res)
select @xmlMsg.value('(/soap:Envelope/soap:Body/Resp:SendWarrantyEmailResponse/Res:SendWarrantyEmailResult/Res:WarrantyNumber)[1]', 'nvarchar(max)')
--select T.N.value('.', 'nvarchar(max)') from @xmlMsg.nodes('/soap:Envelope/soap:Body/SendWarrantyEmailResponse/SendWarrantyEmailResult:SendWarrantyEmailResult') as T(N)
--select @xmlMsg.value('(/soap:Envelope/soap:Body/SendWarrantyEmailResponse/SendWarrantyEmailResult/SendWarrantyEmailResult:HasError)[1]','bit') as test

;with xmlnamespaces(
'http://schemas.xmlsoap.org/soap/envelope/' as [soap],
'http://Web.Services.Warranty/' as Resp,
'http://Web.Services.SendWarrantyResult' as Res)
SELECT
 SendWarrantyEmailResult.value('Res:WarrantyNumber[1]','varchar(max)') AS WarrantyNumber,
 SendWarrantyEmailResult.value('Res:Result[1]','varchar(max)') AS Result,
 SendWarrantyEmailResult.value('Res:HasError[1]','bit') AS HasError,
 SendWarrantyEmailResult.value('Res:MsgUtcTime[1]','datetime') AS MsgUtcTime
FROM @xmlMsg.nodes('/soap:Envelope/soap:Body/Resp:SendWarrantyEmailResponse/Res:SendWarrantyEmailResult') SendWarrantyEmailResults(SendWarrantyEmailResult)

关于xml - SQL Server 2008 查询 Soap XML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10925499/

相关文章:

asp.net - "ASP.NET"错误 : Access to the remote server is denied because no login-mapping exists

java - SP 返回的结果集 - SQL Server - Java

sql - 根据存在条件计算行数

sql - 将字符串分配给 THEN 子句中 case 语句中的变量

Azure Synapse SQL 池未使用 OPENROWSET 识别 csv header

mysql - 通过 phpMyAdmin 将 XML 文件导入 MySQL

sql - 在其他数据库产品中是否有等同于 MS SQL 'FOR XML PATH' 的东西?

java - 为什么 JAXB 不生成完整的类?

sql - 检查索引碎片时 '(' 附近的语法不正确

java - 解析 XML 仅获取注释和日期值