If条件后面跟着一个for循环,在Xquery中不执行



在一个SOAP响应中,我试图使用下面的Xquery代码来检查for循环后面的条件。我试图得到某个元素的计数,然后使用if条件,根据这个if条件,它应该执行for循环。但是出现了一个异常。

这是我在SOAP UI中的Xquery位。

declare variable $datesList :=   ("2013-01-01-00.30.00","2013-01-01-01.00.00","2013-01-01-01.30.00","2013-01-01-02.00.00","2013-01-01-02.30.00","2013-01-01-03.00.00","2013-01-01-03.30.00","2013-01-01-04.00.00");
 <res>
 {
      let $mcId1 :=count(//ZZQAD2UsageTransactionSVC/usagePeriods/usagePeriodsList/SQs/SQsList[1]/mL)
      let $mcId2 :=count(//ZZQAD2UsageTransactionSVC/usagePeriods/usagePeriodsList/SQs/SQsList[2]/mL)
      if($mcId1=8)  
      {
      for $mlList in //ZZQAD2UsageTransactionSVC/usagePeriods/usagePeriodsList/SQs/SQsList[1]/intervals/mL
          return(if($mcId1 > $mcId2)
             then <text>true</text>
             else <text>false</text>)
      }     
 }

下面是运行时出现的异常。

RuntimeException: java.lang.reflect.InvocationTargetException

所以我想请教一下前辈和大师,这段Xquery代码是否正确?

您的查询中有多个语法错误:

  • let子句必须是FLWOR表达式的一部分,该表达式总是以return子句结尾。
  • if没有thenelse不能使用,并且不使用花括号。
  • 开始标记<res>需要在查询结束处匹配结束标记</res>

更正后的查询如下:

declare variable $datesList := (
  "2013-01-01-00.30.00", "2013-01-01-01.00.00",
  "2013-01-01-01.30.00", "2013-01-01-02.00.00",
  "2013-01-01-02.30.00", "2013-01-01-03.00.00",
  "2013-01-01-03.30.00", "2013-01-01-04.00.00"
);
<res>{
  let $mcId1 := count(//ZZQAD2UsageTransactionSVC/usagePeriods/usagePeriodsList/SQs/SQsList[1]/mL)
  let $mcId2 := count(//ZZQAD2UsageTransactionSVC/usagePeriods/usagePeriodsList/SQs/SQsList[2]/mL)
  return if($mcId1 = 8) then (
     for $mlList in //ZZQAD2UsageTransactionSVC/usagePeriods/usagePeriodsList/SQs/SQsList[1]/intervals/mL
     return if($mcId1 > $mcId2)
       then <text>true</text>
       else <text>false</text>
  ) else ()
}</res>

相关内容

  • 没有找到相关文章

最新更新