开发者社区


Web服务 | ASP/ASP.Net | JSP | PHP/Perl | 网站设计
首页 - WEB技术
Web技术
全文搜索:   

如何应用XSLT集合编写麻烦问题的有趣解决方案
作者: Builder
2006-09-24 19:29:29



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

key1=item1,key2=item2,key3=item3

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

列表B

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

表1:功能

模板

说明

collection

用两个字符串建立一个“集合”或“联合数组”,密钥和项目用逗号隔开。

item

返回与密钥相关的项目。

keys

返回集合密钥列表,密钥间用逗号隔开。

collectionAttributes

在输出文件中为所有集合密钥/项目对建立属性。属性名为密钥,项目为值。

collectionElements

在输出文件中为所有集合密钥/项目对建立元素。元素名为密钥,项目为内容。

列表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更新语句执行同样的功能。简言之,更多有趣的材料!

责任编辑:张琎

查看本文的国际来源

【上一页】
声明:
Builder.com.cn(原ZDNet China应用开发频道)原创文章版权所有,未经许可严禁转载,且不构成投资建议。
近期相关报道:
实用技术文档
J2me XML
C/C++ C#
Java Oracle
Mysql .Net
VB.NET CSS
SQL Server 数据库
SQL UNIX
Linux Jsp
PHP Perl
Javascript IIS
XHTML ColdFusion
ASP/ASP.NET Apache
AJAX
订阅技术邮件
订阅"技术圈"杂志!请在下面选择您感兴趣的专题,填写e-mail地址,然后按订阅按钮:
应用开发管理
VS.NET 周刊
Database 周刊
WEB Service周刊
JAVA 周刊
IT 认证
Windows服务器周刊
互联网开发
当Windows Server 2008专家得5000元现金大奖
CNET NETWORKS 中国: 爱卡汽车网 | CNET科技资讯网 | e询网 | CWEEK | 蜂鸟网 | GameSpot China | 个人电脑 | PChome | SPN | 网友世界 | ZDNet China | 中关村在线
CNET NETWORKS 美国: BNET | CNET.com | CNET Download.com | CNET News.com | CNET Reviews | CNET Shopper.com | GameSpot | MP3.com | mySimon | Release 1.0 | Search.com | TechRepublic | TV.com | Webshots | ZDNet
Copyright (c) 2006 CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
ZDNet 公司标识是 CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号