次の問題があります。SQLデータベースにxmlファイルが保存されています。100 ごとに割って、すべての VALUE タグ値を変更する必要があります。ここでは、xml の構造を抽出します。
<HEIGHTC>
<VALUE>15 </VALUE>
<HEIGHTC_DATE>201110180000</HEIGHTC_DATE>
</HEIGHTC>
<HEIGHTC>
<VALUE>15 </VALUE>
<HEIGHTC_DATE>201110250000 </HEIGHTC_DATE>
</HEIGHTC>
<HEIGHTC>
<VALUE>15 </VALUE>
<HEIGHTC_DATE>201111020000 </HEIGHTC_DATE>
</HEIGHTC>
<HEIGHTC>
<VALUE>15 </VALUE>
<HEIGHTC_DATE>201111080000 </HEIGHTC_DATE>
</HEIGHTC>
<HEIGHTC>
<VALUE>20 </VALUE>
<HEIGHTC_DATE>201111150000 </HEIGHTC_DATE>
</HEIGHTC>
<HEIGHTC>
<VALUE>15 </VALUE>
<HEIGHTC_DATE>201111290000 </HEIGHTC_DATE>
</HEIGHTC>
次のクエリを見つけました。
DECLARE @var varchar(50)
set @var='HEIGHTC'
UPDATE tcdc.dbo.BADM_Xml
SET xml_badm.modify('replace value of (/ROOT/*[local-name()=sql:variable("@var")]/VALUE/text())[1] with (/ROOT/*[local-name()=sql:variable("@var")]/VALUE)[1] * 0.01')
一度に1つのノードで正常に動作します.1つの命令ですべてを一般化して更新する方法はありますか? 事前にありがとうディエゴ