一个低级错误,XPath中/和//

2024-01-12 16:38
文章标签 错误 xpath 低级

本文主要是介绍一个低级错误,XPath中/和//,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

昨天我做的一个程序中被发现有一个错误,我检查了程序,但是没有问题,检查XSLT文件,找到了问题所在,这是一个比较低级的失误。
XPath的路径选择错误。
先说明一下程序的结构,数据记录在MS SQL2000中,使用ASP访问数据库,把它展示出来,因为这是一个分级的树形结构,所以我用XML来作为数据集的结构,而没有使用Recordset。它的XML结构如下:
<?xml version="1.0" encoding="gb2312"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified">
 <xs:element name="RootIndex">
  <xs:complexType>
   <xs:sequence>
    <xs:element ref="ItemIndex"/>
   </xs:sequence>
   <xs:attribute name="BranchCode" type="xs:byte" use="required"/>
   <xs:attribute name="StatDate" type="xs:string" use="required"/>
  </xs:complexType>
 </xs:element>
 <xs:element name="ItemIndex">
  <xs:complexType>
   <xs:sequence>
    <xs:element ref="ItemIndex" minOccurs="0" maxOccurs="unbounded"/>
   </xs:sequence>
   <xs:attribute name="ID" type="xs:int" use="required"/>
   <xs:attribute name="Name" type="xs:string" use="required"/>
   <xs:attribute name="Score" type="xs:int" use="required"/>
   <xs:attribute name="Level" type="xs:int" use="required"/>
  </xs:complexType>
 </xs:element>
</xs:schema>

它产生的一个xml实例文档如下:
<?xml version="1.0" encoding="gb2312"?>
<RootIndex BranchCode="100" StatDate="2004-6-1">
 <ItemIndex ID="5" Name="根节点" Score="15" Level="1">
  <ItemIndex ID="6" Name="子节点6" Score="3" Level="2"/>
  <ItemIndex ID="7" Name="子节点7" Score="8" Level="2">
   <ItemIndex ID="8" Name="子节点8" Score="4" Level="3"/>
   <ItemIndex ID="9" Name="子节点9" Score="4" Level="3"/>
  </ItemIndex>
  <ItemIndex ID="10" Name="子节点10" Score="4" Level="2"/>
 </ItemIndex>
</RootIndex>


在网页的展示当中,我使用XSLT来将XML数据集转换成HTML文档,结果展示这是一个具有分级结构的表格。

因为叶节点的@Score属性能够被用户编辑,父节点需要统计叶节点的@Score,网页提供一个提交的按钮,只有提交之后,程序才重新计算总分,往数据库里记录,在没有提交分数之前,用xslt把父节点上的@Score重新计算,然后刷新表格区的信息。
在xslt中的求子节点分数和的表达式应该为:sum(*/@Score),但是在路径选择上,我犯了一个错误,我把它写成了sum(*//@Score)。
路径*/@Score表示对当前子节点中的@Score属性集合
路径*//@Score表示对当前节点的所有后代节点中的@Score属性

错误的xslt把ID为5的节点中的@Score计算为23

XPath中,/和//的区别就是一个选择子节点,一个选择后代节点,因此计算结果出现了错误。

 

这篇关于一个低级错误,XPath中/和//的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/598484

相关文章

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.

Java编译错误java.lang.NoSuchFieldError的解决方案详析

《Java编译错误java.lang.NoSuchFieldError的解决方案详析》java.lang.NoSuchFieldError是Java中的一种运行时错误,:本文主要介绍Java编译错... 目录前言解决方案1. 统一JDK版本环境2. 优化maven-compiler-plugin配置3. 清

Navicat连接Mysql8.0.11出现1251错误的解决方案

《Navicat连接Mysql8.0.11出现1251错误的解决方案》在重装电脑并安装最新版MySQL后,Navicat和Sqlyog连接MySQL时遇到的1251和2058错误,通过将MySQL用户... 目录Navicat连接mysql8.0.11出现1251错误原因分析解决问题方法有两种总结Navic

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

SpringBoot3匹配Mybatis3的错误与解决方案

《SpringBoot3匹配Mybatis3的错误与解决方案》文章指出SpringBoot3与MyBatis3兼容性问题,因未更新MyBatis-Plus依赖至SpringBoot3专用坐标,导致类冲... 目录SpringBoot3匹配MyBATis3的错误与解决mybatis在SpringBoot3如果

nginx配置错误日志的实现步骤

《nginx配置错误日志的实现步骤》配置nginx代理过程中,如果出现错误,需要看日志,可以把nginx日志配置出来,以便快速定位日志问题,下面就来介绍一下nginx配置错误日志的实现步骤,感兴趣的可... 目录前言nginx配置错误日志总结前言在配置nginx代理过程中,如果出现错误,需要看日志,可以把

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at