我有一些表示数学表达式树的XML数据并希望将其转换为平坦的数学公式。听起来很简单,但SQL Server中的XQuery限制目前阻止我成功(没有递归函数,“异构”结果等问题)。使用SQL Server 2008 XQuery将XML树转换为平面文本
表达式可以是任意的嵌套深度。下面是一个示例(该数据在一个表中的XML列以后,但这是不够好测试这里):
DECLARE @expr xml;
SET @expr = '<expression aggregator="+">
<indicator>122F277B-A241-7944-BC38-3BB5E8B213AF</indicator>
<indicator>7DD46849-2193-EB41-8BAB-CE0C45255249</indicator>
<expression aggregator="*">
<expression aggregator="/">
<indicator>122F277B-A241-7944-BC38-3BB5E8B213AF</indicator>
<indicator>27F3156D-FDA7-1E44-B545-7F27A48D9838</indicator>
</expression>
<indicator>ADFCEF34-9877-DE4E-8A00-13576437D82B</indicator>
<value>12</value>
</expression>
<expression aggregator="-">
<indicator>ADFCEF34-9877-DE4E-8A00-13576437D82B</indicator>
<indicator>75896474-C197-1C44-8EAA-8FE9D0AB2663</indicator>
</expression>
<indicator>27F3156D-FDA7-1E44-B545-7F27A48D9838</indicator>
</expression>';
所需的结果将是(空白是微不足道的):
(
[122F277B-A241-7944-BC38-3BB5E8B213AF] +
[7DD46849-2193-EB41-8BAB-CE0C45255249] +
(
(
[122F277B-A241-7944-BC38-3BB5E8B213AF]/
[27F3156D-FDA7-1E44-B545-7F27A48D9838]
) *
[ADFCEF34-9877-DE4E-8A00-13576437D82B] *
12
) +
(
[ADFCEF34-9877-DE4E-8A00-13576437D82B] -
[75896474-C197-1C44-8EAA-8FE9D0AB2663]
) +
[27F3156D-FDA7-1E44-B545-7F27A48D9838]
)
有人能够很好地掌握SQL Server 2008(R2)中的XQuery来执行此转换吗?
您不能处理未定义deph树不一般的递归。这就是为什么这个XQuery引擎有它自己的标签... – 2011-04-20 22:03:26
@Alejandro,抱歉没有收到这个标签,感谢编辑。 – Lucero 2011-04-20 23:56:05