如何在tsql中查询xml列

我有一个表T1,在SQL Server 2008上有一个XML列EventXML。我想查询某个节点包含特定值的所有行。更好的是,我想检索不同节点中的值。表T1:
T1:
   EventID,int
   EventTime,datetime
   EventXML,XML

这里是一个示例XML层次结构:

<Event>
   <Indicator>
      <Name>GDP</Name>
   </Indicator>
   <Announcement>
      <Value>2.0</Value>
      <Date>2012-01-01</Date>
   </Announcement>
</Event>

>如何找到与“GDP”相关的所有行指标;
>如何获得“GDP”的所有值指标;

这个怎么样?
SELECT 
    EventID,EventTime,AnnouncementValue = t1.EventXML.value('(/Event/Announcement/Value)[1]','decimal(10,2)'),AnnouncementDate = t1.EventXML.value('(/Event/Announcement/Date)[1]','date')
FROM
    dbo.T1
WHERE
    t1.EventXML.exist('/Event/Indicator/Name[text() = "GDP"]') = 1

它将找到所有/ Event / Indicator / Name等于GDP的行,然后它将显示< Announcement> /< Value>和<公告> /< Date>为这些行。

SQLFiddle demo

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念
xml文件介绍及使用
xml编程(一)-xml语法
XML文件结构和基本语法
第2章 包装类
XML入门的常见问题(二)
Java对象的强、软、弱和虚引用
JS解析XML文件和XML字符串详解
java中枚举的详细使用介绍
了解Xml格式
XML入门的常见问题(四)
深入SQLite多线程的使用总结详解
PlayFramework完整实现一个APP(一)
XML和YAML的使用方法
XML轻松学习总节篇