除了使用COLUMN[1]/@value
下面的元素索引,是否可以通过指定属性名称来检索列值,例如:COLUMN[@name=”Prod_ID”]/@value
?
当我尝试时,我得到了这个错误:
消息 2389,级别 16,状态 1,第 41 行
XQuery [value()]:'value()' 需要一个单例(或空序列),找到类型为 'xdt:untypedAtomic *' 的操作数
我的代码:
DECLARE @xml AS XML = '<DATA>
<ROW RowNumber="1">
<COLUMN Name="ProdID" Value="1234" />
<COLUMN Name="AppID" Value="20144" />
<COLUMN Name="ConsentDesc" Value="My Description" />
<COLUMN Name="ConsentVer" Value="" />
<COLUMN Name="ConsentAcceptance" Value="6789" />
<COLUMN Name="ConsentType" Value="TermsAndConditions" />
<COLUMN Name="CreatedDate" Value="8/22/2014 3:04:29 PM" />
</ROW>
</DATA>'
SELECT
m.c.value('@RowNumber', 'varchar(50)') AS RowNumber ,
m.c.value('COLUMN[1]/@Value', 'varchar(50)') AS [ProdID] ,
m.c.value('COLUMN[2]/@Value', 'varchar(50)') AS [AppID] ,
m.c.value('COLUMN[3]/@Value', 'varchar(50)') AS [ConsentDesc.] ,
m.c.value('COLUMN[4]/@Value', 'varchar(50)') AS [ConsentVer.] ,
m.c.value('COLUMN[5]/@Value', 'varchar(50)') AS [ConsentAcceptance] ,
m.c.value('COLUMN[6]/@Value', 'varchar(50)') AS [ConsentType] ,
m.c.value('COLUMN[7]/@Value', 'varchar(50)') AS [CreatedDate]
FROM
@xml.nodes('DATA/ROW') AS m ( c )
.value 方法必须始终返回单个值,因此您通常将其括在括号中并将序数(例如 [1] )移动到末尾。这是一个例子: