WEB开发网
开发学院数据库DB2 用SQL查询DB2 XML数据 阅读

用SQL查询DB2 XML数据

 2008-05-15 14:58:11 来源:WEB开发网   
核心提示:“投影” XML 元素值现在让我们考虑一种稍微有些不同的情景,假设您想将 XML 值投影到返回的结果集,用SQL查询DB2 XML数据(5),换句话说,我们要从 XML 文档中检索一个或多个元素值,您已经熟悉了一个可以帮您实现这一点的 SQL/XML 函数 —— 那就是

“投影” XML 元素值

现在让我们考虑一种稍微有些不同的情景,假设您想将 XML 值投影到返回的结果集。换句话说,我们要从 XML 文档中检索一个或多个元素值。有很多方法可以做这件事。首先我们使用 XMLQuery 函数来检索一个元素的值,然后使用 XMLTable 函数来检索多个元素的值,然后将这些映射到一个 SQL 结果集的列。

我们来考虑如何解决之前摆在我们面前的一个问题:如何创建一个列出 Gold 客户的 email 地址的报告。下面 清单 7 中的查询调用 XMLQuery 函数来完成这项任务:

清单 7. 检索符合条件的客户的 email 信息
select xmlquery('$c/Client/email'
passing contactinfo as "c")
from clients
where status = 'Gold'

第一行指定要返回根元素 "Client" 的 "email" 子元素的值。第二行和第三行表明 DB2 在哪里可以找到该信息 —— 在 "clients" 表的 "contactinfo" 列中。第四行进一步限制查询,表明您只对 Gold 客户的 email 地址感兴趣。这个查询将返回一组 XML 元素和值。例如,如果有 500 名 Gold 客户,每个客户有一个 email 地址,那么输出将是一个单列的结果集,一共有 500 行,如 清单 8 所示:

清单 8. 之前查询的示例输出
1
--------------------------------------------
<email>user5976@anyprovider.com</email>
. . .
<email>someID@yahoo.com</email>  

如果每个 Gold 客户有多个 email 地址,那么需要指示 DB2 只返回首要的地址(也就是在客户的 "contactinfo" 文档中找到的第一个 email 地址)。为此,可以修改查询的第一行中的表达式:

清单 9. 检索每个符合条件的客户的第一个 email 地址
select xmlquery('$c/Client/email[1]'
passing contactinfo as "c")
from clients
where status = 'Gold'

最后,如果有些 Gold 客户没有 email 地址,那么可能要编写一个查询从结果集中排除 null 值。为此可以修改之前的查询,添加另一个谓词到 WHERE 中,以测试是否缺少 email 信息。您已经熟悉了一个可以帮您实现这一点的 SQL/XML 函数 —— 那就是 XMLExists。清单 10 展示了如何重新编写之前的查询,以便过滤掉那些联系方式(存储为 XML 文档)中缺少 email 地址的 Gold 客户的行:

清单 10. 对于至少有一个 email 地址的客户,检索每个符合条件的客户的第一个 email 地址
select xmlquery('$c/Client/email[1]'
passing contactinfo as "c")
from clients
where status = 'Gold'
and xmlexists('$c/Client/email' passing contactinfo as "c")

上一页  1 2 3 4 5 6 7 8 9 10  下一页

Tags:SQL 查询 DB

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接