- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
使用DOM和XSL来格式化由Java提取的数据
Java可从任何JDBC兼容数据库提取数据,将数据转换成一个DOM对象,然后用XSL将数据格式化成需要的形式。在上一篇文章中,我们演示了如何从数据库中程序化地提取数据。现在,让我们讨论如何生成DOM对象,并用一个XSL样式表来格式化数据。这样一来,最终的输出就可用于任何应用程序,只要你为它们提供需要的输入。
生成DOM文档
Java的最新版本支持JAXP XML处理,并实现了由万维网协会(W3C)定义的DOM API。使用这些相容于JAXP的版本,只需3行代码即可创建一个DOM文档对象,其中用到了JAXP factory和builder方法:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.newDocument();
我们创建一个名为resultset的根元素,并把它添加到文档对象中
Element root = document.createElement(resultset);
document.appendChild(root);
resultset游标遍历结果集时,在根元素中添加包含行数据的一个新元素:
Element nextRow = document.createElement(row);
列计数必须从ResultSetMetaData对象中读取;在本项目的数据库数据提取阶段,它必须是已经定义好的:
int columnCount = rsmd.getColumnCount();
列名要用for循环来检索;针对每个列名,都添加一个name节点,它带有一个子TextNode,其中包含用于一个names元素的名值:
String[] columnNames = new String[columnCount];
Element names = document.createElement(names);
for (int i = 0; i 〈 columnCount; i++){
/* the first column is 1, the second is 2, ... */
columnNames[i] = rsmd.getColumnName(i + 1);
Element nextNameNode = document.createElement(name);
Text nextName = document.createTextNode(columnNames[i]);
nextNameNo
de.appendChild(nextName);
names.appendChild(nextNameNode);
}
列索引从1开始,而非从0开始。读取每个数据行时,列值都在一个for循环中作为字符串来泛化地检索,这个for循环将读取每一个列值:
/* Move the cursor through the data one row at a time. */
while(resultSet.next()){
/* Create an Element node for each row of data. */
Element nextRow = document.createElement(row);
if (debug) System.out.println(new row);
for (int i = 0; i 〈 columnCount; i++){
/* Create an Element node for each column value. */
Element nextNode = document.createElement(columnNames[i]);
/* the first column is 1, the second is 2, ... */
/* getString() will retrieve any of the basic SQL types*/
Text text = document.createTextNode(resultSet.getString(i + 1));
nextNode.appendChild(text);
nextRow.appendChild(nextNode);
}
root.appendChild(nextRow);
}
所有数据都转换到一个DOM文档对象中之后,连接就可关闭。DataBaseHandler永远不需要进行文件操作。XML
您可能关注的文档
- 最终二号线车站组卷样板.xls
- 佐治亚理工学院城市与区域规划.pdf
- 作文原题+考场佳作+专家点评.doc
- 作业场所所常见职业危害辨识手册.doc
- 作业场所职业病危害申报与.ppt
- 做大企业规模 做优产业特色.doc
- 做好就业和自主创业的准备(最终).ppt
- 做外贸必须懂航运.doc
- 做外贸如何选择产品.doc
- 做一名合格的销售人员.ppt
- 河南省新乡市第一中学等校2025-2026学年九年级上学期12月月考历史试题(含解析).docx
- 河南省郑州市实验中学2025-2026学年高一上学期第二次月考政治试题(含解析).docx
- 江苏省南通市通州区西亭初级中学2025-2026学年上学期七年级英语12月试卷.docx
- 河北省秦皇岛市山海关区第一中学2025-2026学年高三上学期11月月考英语试卷.docx
- 江苏省南京师范大学附属中学新城初级中学2025-2026学年九年级上学期12月月考英语试卷.docx
- 河北省唐山市丰南区经安中学四校联考2025-2026学年九年级上学期12月月考历史试题.docx
- 河南省安阳市北关区莲花学校2025-2026学年上学期八年级历史第三次月考试题(含答案).docx
- 安徽省黄山地区2025-2026学年七年级上学期期中考试英语试题(原卷版).docx
- 2026届云南省西南名校联盟高三上学期高考诊断性联考政治试题(含解析).docx
- 河南省周口市商水县第二高中2025-2026学年高一上学期12月月考政治试题(含答案).docx
最近下载
- IPC-2223E-中文-2020 CN 挠性和刚挠性印制板计件分标准.pdf VIP
- 劳动合同标准版劳动合同劳动合同.doc VIP
- 比亚迪发动机维修手册.doc
- 公路工程新技术.pptx VIP
- 永诚财险建筑施工行业安全生产责任保险(2024 年版)条款.pdf VIP
- SN/T 3992-2014_进境非人灵长类实验动物指定隔离场建设规范.pdf VIP
- 精品解析:2024-2025学年浙江省温州市龙港市统编版五年级上册期末考试语文试卷(解析版).docx VIP
- 中国临床肿瘤学会(csco)胆道恶性肿瘤诊疗指南2025.docx VIP
- 【2017年整理】光接入网维护操作标准化手册-----接入有源设备维护.doc VIP
- 新22S3 室外排水工程建筑工程图集.docx VIP
原创力文档


文档评论(0)