2013-07-23 134 views
4
<SSRSReport> 
    <OutputType>email</OutputType> 
    <email> 
    <emailTo>xyz.com</emailTo> 
    <emailReplyTo>[email protected]</emailReplyTo> 
    <emailSubject>status report</emailSubject> 
    <emailBody> 
</email> 
</SSRSReport> 

需要您的帮助,从xml类型的一列中存在的表中选择sql中的节点值。我已经尝试的是:如何从表列中获取xml值

select 
    T.id, 
    T.xml_data.value('(SSRSReport/email/@emailTo)[1]', 'varchar(50)') as PropertyName 
from 
    abc as T 
where 
    T.xml_data.exist('/email/emailTo') = 'xyz.com' 

但它返回属性名称列为null。

回答

5

你很接近 - 但由于<emailTo>元素(不是属性),你需要使用:

select 
T.id, 
T.xml_data.value('(SSRSReport/email/emailTo)[1]', 'varchar(50)') as PropertyName 

使用/emailTo(不/@emailTo)作为XPath表达式的最后一部分。

另外,.exist()函数只能检查是否存在XML元素(或属性),因此您可以检查是否存在<emailTo>元素(或不存在),但不能与值进行比较。所以你的WHERE条款是无效的 - 你可能想要:

where 
    T.xml_data.value('(SSRSReport/email/emailTo)[1]', 'varchar(50)') = 'xyz.com' 
+0

感谢兄弟..它完全适合我... –