一位前任经理把我描述成创作“疯狂科学材料”的人,这已不是什么秘密,这里他使用了“材料”这个词。这个说法说明我热爱解决应用程序开发的各方面问题。通常,我的创作并不特别,只用于解决手边出现的问题。但有时候也可用在其他方面,有点像一个解决问题的锤子。
最近我建立了一个解决方案,它首先解析存储在一个表格中用来记录插入项的SQL插入语句。表格中包含建立SQL插入语句所需的一切信息,如用户ID、日期和SQL插入语句本身。图A显示了和XML一样的记录集。
图A
象XML一样的记录集
总体上,表格不是问题,问题在于我必须处理其中的一个列。特别地,这个列中包含SQL插入语句。你知道,我的任务就是为非技术人员建立一个即时报告,向他们清楚说明所作的改变。所以,遗憾的是,在报告中加入大量SQL源代码是行不通的。另外,由于网络是以VBScript编写的典型ASP,这使问题更加复杂。总而言之,这是一个相当麻烦的任务,但生活中总是充满挑战。
实际上,最大的问题在于解决列名与列值相关联的问题。幸运的是,如列表A所示,通过非常规使用substring-before和substring-after函数,可能建立两个变量。第一个变量包含列名,第二个变量为列值。有趣的是,由于SQL插入项单个元素的语法,这些变量用逗号隔开。
列表A
 

完成第一步后,我开始着重下一步操作,将列名与对应的值联系起来。由于XSL中的变量不会发生变化,所以有必要建立一个新变量来保存相关联的列名和列值。另外,因为缺乏数组,所以还要建立一个变量,它的内部结构使恢复必要的信息相对容易。最终我设计出下面这些代码:

key1=item1,key2=item2,key3=item3

对!在这个时候,问题出现转机;我意识到,经过一个小时的工作后,我得到一个集合或联合数组(如果你更喜欢这个名称的话)。一旦前面出现曙光,问题变得更加容易。如列表B所示,其中的模板建立上述结构。

列表B

由于现在信息是一个集合,而非一团糟,所以我们指望出现某种功能。但不幸的是,考虑这些期待时,不得不衡量XSL的局限与优势。1中列出的为执行XSL集合而编写的单个指定模板的功能,列表C列表D分别为最终式样表和一个测试XML文件。

表1:功能

列表C

列表D

将上面的XSL样式表应用于XML文件中,把含有SQL插入语句的列转变成某种有用的东西就变得相对容易一些。列表E中显示的输出XML文件在随后的转换中也更容易处理。

列表E:输出的XML文件

<?xml version="1.0" encoding="UTF-8"?>

<result>

<insert>

<column1>11</column1>

<column2>22</column2>

<column3>33</column3>

</insert>

<insert>

<column1>44</column1>

<column2>55</column2>

<column3>66</column3>

</insert>

</result>

有趣的解决方案

由于某种原因,一得到和上面类似的任务,我最先想到的是,“我的简历是最新的吗?”幸运的是,这种绝对的恐慌只持续大约两分钟左右,给为麻烦问题寻找有趣的解决方案留下大量时间。只要稍稍作一下修改,这些模板就可用来对SQL更新语句执行同样的功能。简言之,更多有趣的材料!

本日志由 胡子 于 2006-09-24 19:29:29 发表到 技术文章 中,目前已经被浏览 1164 次,评论 0 次;

作者添加了以下标签: 如何应用XSLT集合编写麻烦问题有趣解决方案