以下查詢試圖選擇給定節點的子節點。如何使用變量而不是硬編碼子節點,以便我可以將它們作爲SProc中的參數傳遞?XQUERY - 如何在'value()'函數中使用sql:變量?
declare @T table(XMLCol xml)
insert into @T values
('<Root xmlns="http://tempuri.org" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<Elem1 type="T1">
<Name type="string" display="First name">John</Name>
<TimeZone display="Time zone">
<children>
<DisplayName type="string" display="Display name">GMT Standard Time</DisplayName>
<HiddenName type="string" display="Hidden name">GMT</HiddenName>
</children>
</TimeZone>
</Elem1>
</Root>')
declare @Node varchar(50)
set @Node = 'TimeZone'
select N.value('(children/DisplayName)[1]', 'varchar(100)') as Value
from @T as T
cross apply T.XMLCol.nodes('//*[local-name()=sql:variable("@Node")]') as X(N)
我已經試過了。似乎沒有這樣工作。 –
請再試一次。打電話很難:)。 –
儘管這樣做,但我仍然如何用一個變量替換整個子句 - '(// TimeZone/children/* [local-name()= sql:variable(「@ NodeX」)]] [1]' –