Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/76.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用名称空间更新SQL Server中的XML属性_Sql_Sql Server_Xml_Sql Server 2008_Tsql - Fatal编程技术网

使用名称空间更新SQL Server中的XML属性

使用名称空间更新SQL Server中的XML属性,sql,sql-server,xml,sql-server-2008,tsql,Sql,Sql Server,Xml,Sql Server 2008,Tsql,我有一个包含xml列“Data”的表。我的要求是在升级代码时更改属性Uri和InstanceName。我写了下面的更新声明来完成这项工作。当我执行时,我看到1行受影响,但不幸的是,它没有更新任何内容。我们将非常感谢您的帮助。谢谢 CREATE TABLE [dbo].[Test_TBD]( [Id] [int] NULL, [Data] [xml] NULL ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] GO WITH XMLNAMESP

我有一个包含xml列“Data”的表。我的要求是在升级代码时更改属性Uri和InstanceName。我写了下面的更新声明来完成这项工作。当我执行时,我看到1行受影响,但不幸的是,它没有更新任何内容。我们将非常感谢您的帮助。谢谢

CREATE TABLE [dbo].[Test_TBD](
    [Id] [int] NULL,
    [Data] [xml] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

GO   

 WITH XMLNAMESPACES(DEFAULT 'http://www.tech.com/datafeed/dfx/2010/04')
 UPDATE Test_TBD set
Data.modify('replace value of (/DataFeed/Transporter/ArcherWebServiceTransportActivity/@Uri)[1] with "https://arcs-x"');

 UPDATE Test_TBD set
 Data.modify('replace value of (/DataFeed/Transporter/ArcherWebServiceTransportActivity/@InstanceName)[1] with "ARCS-X"');
下面是数据列中的示例数据

'<DataFeed xmlns="http://www.tech.com/datafeed/dfx/2010/04" xmlns:plugin="pluginExtensions" Type="TODO" Guid="TODO" UserAccount="DF_LEAN_PopulateCommentsSubForm" Locale="en-US" DateFormat="" ThousandSeparator="" NegativeSymbol="" DecimalSymbol="" SendingNotifications="false" SendJobStatusNotifications="false" RecipientUserIds="" RecipientGroupIds="" RecipientEmailAddresses="" Name="CI_C11.01_Lean-Lean_Reject Comments_A2A" >
      <Transporter>
        <transporters:ArcherWebServiceTransportActivity xmlns:transporters="clr-namespace:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed" xmlns:out="clr-namespace:ArcherTech.DataFeed;assembly=ArcherTech.DataFeed" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:compModel="clr-namespace:ArcherTech.DataFeed.ComponentModel;assembly=ArcherTech.DataFeed" xmlns:channel="clr-namespace:ArcherTech.DataFeed.Engine.Channel;assembly=ArcherTech.DataFeed" xmlns:engine="clr-namespace:ArcherTech.DataFeed.Engine;assembly=ArcherTech.DataFeed" xmlns:kernel="clr-namespace:ArcherTech.Kernel.Channel;assembly=ArcherTech.Kernel" xmlns="clr-namespace:ArcherTech.DataFeed;assembly=ArcherTech.DataFeed" xmlns:schema="clr-namespace:System.Xml.Schema;assembly=System.Xml" xmlns:xmlLinq="clr-namespace:System.Xml.Linq;assembly=System.Xml" xmlns:domain="clr-namespace:ArcherTech.Common.Domain;assembly=ArcherTech.Common" xmlns:s="clr-namespace:System;assembly=mscorlib" x:Key="transportActivity" SearchType="ReportId" Uri="https://arcs-d" RecordsPerFile="100" ReportID="EC514865-88D5-49CE-A200-7769EC1C2A88" UseWindowsAuth="false" IsWindowsAuthSpecific="false" WindowsAuthUserName="i9XzCczAQ7J2rHwkg6wG9QF8+O9NCYJZP6y5Kzw4be0+cdvUaGu/9+rHuLstU736pnQrRcwmnSIhd6oPKIvnLA==" WindowsAuthPassword="+y0tCAKysxEMSGv1unpHxfg6WjH5XWylgP45P5MLRdQ6+zAdOLSVy7s3KJa3+9j2i83qn8I8K7+1+QBlCJT1E7sLQHWRFOCEdJgXaIr1gWfUEO+7kjuJnZcIEKZJa2wHyqc2Z08J2SKfdCLh7HoLtg==" WindowsAuthDomain="" ProxyName="" ProxyPort="8080" ProxyUsername="" ProxyPassword="" ProxyDomain="" IsProxyActive="False" ProxyOption="None" InstanceName="ARCS-D" TempFileOnSuccessAction="DoNothing" TempFileOnSuccessRenameString="" TempFileOnErrorAction="DoNothing" TempFileOnErrorRenameString="" Transform="{engine:DataFeedBinding Path=Transform}" SessionContext="{engine:DataFeedBinding Path=Session}">
          <transporters:ArcherWebServiceTransportActivity.Credentials>
            <NetworkCredentialWrapper UserName="TeSZmI1SqO0eJ0G2nDVU+glFg/9eZfeMppYQnPfbeg8=" Password="Slt4VHqjkYscWyCwZK40QJ7KOQroG9OTKr+RGt9bQjE=" />
          </transporters:ArcherWebServiceTransportActivity.Credentials>
        </transporters:ArcherWebServiceTransportActivity>
      </Transporter> 
    </DataFeed>'
'
'

您需要在更新语句中使用
和XMLNAMESPACES
,并且需要使用命名空间
clr名称空间:archetech.DataFeed.Activities.Transporters;assembly=archetech.DataFeed

对于
传输程序:ArcherWebServiceTransportActivity
节点

使用XMLNAMESPACES的
(默认值'http://www.tech.com/datafeed/dfx/2010/04',
'clr命名空间:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed'as t)
更新测试TBD集
Data.modify((/DataFeed/Transporter/t:ArcherWebServiceTransportActivity/@Uri)[1]的值替换为“https://arcs-x"');
使用XMLNAMESPACES(默认值'http://www.tech.com/datafeed/dfx/2010/04',
'clr命名空间:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed'as t)
更新测试TBD集
Data.modify((/DataFeed/Transporter/t:ArcherWebServiceTransportActivity/@InstanceName)[1]的值替换为“ARCS-X”);

您需要在更新语句中使用
和XMLNAMESPACES
,并且需要使用命名空间
clr名称空间:archetech.DataFeed.Activities.Transporters;assembly=archetech.DataFeed

对于
传输程序:ArcherWebServiceTransportActivity
节点

使用XMLNAMESPACES的
(默认值'http://www.tech.com/datafeed/dfx/2010/04',
'clr命名空间:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed'as t)
更新测试TBD集
Data.modify((/DataFeed/Transporter/t:ArcherWebServiceTransportActivity/@Uri)[1]的值替换为“https://arcs-x"');
使用XMLNAMESPACES(默认值'http://www.tech.com/datafeed/dfx/2010/04',
'clr命名空间:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed'as t)
更新测试TBD集
Data.modify((/DataFeed/Transporter/t:ArcherWebServiceTransportActivity/@InstanceName)[1]的值替换为“ARCS-X”);

只是为了完整性,正如您已经找到了XMLNAMESPACES的答案一样,还有其他方法(但无可否认,我同意Mikaels的建议)

DECLARE@xml=
'
';
选择'original:'+@xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1],'varchar(max)'+'/'+@xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1],'varchar(max)');
--声明为XML_DML一部分的名称空间
SET@xml.modify('declare namespace ns='http://www.tech.com/datafeed/dfx/2010/04";
declare namespace t=“clr namespace:archetech.DataFeed.Activities.Transporters;assembly=archetech.DataFeed”;
将(/ns:DataFeed/ns:Transporter/t:ArcherWebServiceTransportActivity/@Uri)[1]的值替换为“https://arcs-x"');
--Uri已更改
选择“已声明:”+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1],“varchar(max)”+“/”+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1],“varchar(max)”;
--用“*”修饰的名称空间
SET@xml.modify((/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1]的值替换为“ARCS-X”);
--InstanceName已更改
选择“星号:”+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1],“varchar(max)”+”/“+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1],“varchar(max)”;

只是为了完整性,正如您已经找到了XMLNAMESPACES的答案一样,还有其他方法(但无可否认,我同意Mikaels的建议)

DECLARE@xml=
'
';
选择'original:'+@xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1],'varchar(max)'+'/'+@xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1],'varchar(max)');
--声明为XML_DML一部分的名称空间
SET@xml.modify('declare namespace ns='http://www.tech.com/datafeed/dfx/2010/04";
declare namespace t=“clr namespace:archetech.DataFeed.Activities.Transporters;assembly=archetech.DataFeed”;
将(/ns:DataFeed/ns:Transporter/t:ArcherWebServiceTransportActivity/@Uri)[1]的值替换为“https://arcs-x"');
--Uri已更改
选择“已声明:”+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1],“varchar(max)”+“/”+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1],“varchar(max)”;
--用“*”修饰的名称空间
SET@xml.modify((/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1]的值替换为“ARCS-X”);
--InstanceName已更改
选择“星号:”+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1],“varchar(max)”+”/“+@xml.value(”(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1],“varchar(max)”;

我已将/DataFeed/Transporter/ArcherWebServiceTransportActivity/@Uri替换为/DataFeed/Transporter/*/@Uri,只是为了通过选择“全部”来验证它是否正常工作。它可能在这种情况下工作,但我希望选择所需的节点并进行更新。请说明我遗漏了什么。谢谢,我很高兴
DECLARE @xml XML=
'<DataFeed xmlns="http://www.tech.com/datafeed/dfx/2010/04" xmlns:plugin="pluginExtensions" Type="TODO" Guid="TODO" UserAccount="DF_LEAN_PopulateCommentsSubForm" Locale="en-US" DateFormat="" ThousandSeparator="" NegativeSymbol="" DecimalSymbol="" SendingNotifications="false" SendJobStatusNotifications="false" RecipientUserIds="" RecipientGroupIds="" RecipientEmailAddresses="" Name="CI_C11.01_Lean-Lean_Reject Comments_A2A" >
      <Transporter>
        <transporters:ArcherWebServiceTransportActivity xmlns:transporters="clr-namespace:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed" xmlns:out="clr-namespace:ArcherTech.DataFeed;assembly=ArcherTech.DataFeed" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:compModel="clr-namespace:ArcherTech.DataFeed.ComponentModel;assembly=ArcherTech.DataFeed" xmlns:channel="clr-namespace:ArcherTech.DataFeed.Engine.Channel;assembly=ArcherTech.DataFeed" xmlns:engine="clr-namespace:ArcherTech.DataFeed.Engine;assembly=ArcherTech.DataFeed" xmlns:kernel="clr-namespace:ArcherTech.Kernel.Channel;assembly=ArcherTech.Kernel" xmlns="clr-namespace:ArcherTech.DataFeed;assembly=ArcherTech.DataFeed" xmlns:schema="clr-namespace:System.Xml.Schema;assembly=System.Xml" xmlns:xmlLinq="clr-namespace:System.Xml.Linq;assembly=System.Xml" xmlns:domain="clr-namespace:ArcherTech.Common.Domain;assembly=ArcherTech.Common" xmlns:s="clr-namespace:System;assembly=mscorlib" x:Key="transportActivity" SearchType="ReportId" Uri="https://arcs-d" RecordsPerFile="100" ReportID="EC514865-88D5-49CE-A200-7769EC1C2A88" UseWindowsAuth="false" IsWindowsAuthSpecific="false" WindowsAuthUserName="i9XzCczAQ7J2rHwkg6wG9QF8+O9NCYJZP6y5Kzw4be0+cdvUaGu/9+rHuLstU736pnQrRcwmnSIhd6oPKIvnLA==" WindowsAuthPassword="+y0tCAKysxEMSGv1unpHxfg6WjH5XWylgP45P5MLRdQ6+zAdOLSVy7s3KJa3+9j2i83qn8I8K7+1+QBlCJT1E7sLQHWRFOCEdJgXaIr1gWfUEO+7kjuJnZcIEKZJa2wHyqc2Z08J2SKfdCLh7HoLtg==" WindowsAuthDomain="" ProxyName="" ProxyPort="8080" ProxyUsername="" ProxyPassword="" ProxyDomain="" IsProxyActive="False" ProxyOption="None" InstanceName="ARCS-D" TempFileOnSuccessAction="DoNothing" TempFileOnSuccessRenameString="" TempFileOnErrorAction="DoNothing" TempFileOnErrorRenameString="" Transform="{engine:DataFeedBinding Path=Transform}" SessionContext="{engine:DataFeedBinding Path=Session}">
          <transporters:ArcherWebServiceTransportActivity.Credentials>
            <NetworkCredentialWrapper UserName="TeSZmI1SqO0eJ0G2nDVU+glFg/9eZfeMppYQnPfbeg8=" Password="Slt4VHqjkYscWyCwZK40QJ7KOQroG9OTKr+RGt9bQjE=" />
          </transporters:ArcherWebServiceTransportActivity.Credentials>
        </transporters:ArcherWebServiceTransportActivity>
      </Transporter> 
    </DataFeed>';


SELECT 'original: ' + @xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1]','varchar(max)') + ' / ' + @xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1]','varchar(max)');

--namespaces declared as part of the XML_DML
SET @xml.modify('declare namespace ns="http://www.tech.com/datafeed/dfx/2010/04";
                 declare namespace t="clr-namespace:ArcherTech.DataFeed.Activities.Transporters;assembly=ArcherTech.DataFeed"; 
                 replace value of (/ns:DataFeed/ns:Transporter/t:ArcherWebServiceTransportActivity/@Uri)[1] with "https://arcs-x"');

--The Uri is changed
SELECT 'declared: ' + @xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1]','varchar(max)') + ' / ' + @xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1]','varchar(max)');

--namespace tricked out with the "*"
SET @xml.modify('replace value of (/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1] with "ARCS-X"');

--The InstanceName changed
SELECT 'asterisk: ' + @xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@Uri)[1]','varchar(max)') + ' / ' + @xml.value('(/*:DataFeed/*:Transporter/*:ArcherWebServiceTransportActivity/@InstanceName)[1]','varchar(max)');