Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date
Added by adian miko over 7 years ago
Hello,
I got Error when calling Expresion $v2 le xs:date($v1 ), Currently i used Saxon He 9.7 .18. I know that version is not Supported scheme Aware in Home Edition Version, So is any solution to resolve my case?
This Is my Complete Excpetion :
net.sf.saxon.trans.XPathException: Cannot compare xs:untypedAtomic to xs:date at net.sf.saxon.expr.ValueComparison.compare(ValueComparison.java:735) at net.sf.saxon.expr.ValueComparison.effectiveBooleanValue(ValueComparison.java:695) at net.sf.saxon.xpath.XPathExpressionImpl.evaluate(XPathExpressionImpl.java:202) at be.xbrlcore.linkbase.FormulaLinkbase.assertValue(FormulaLinkbase.java:964) at be.xbrlcore.linkbase.FormulaLinkbase$AssertValueCallable.call(FormulaLinkbase.java:2042) at be.xbrlcore.linkbase.FormulaLinkbase$AssertValueCallable.call(FormulaLinkbase.java:1) at java.util.concurrent.FutureTask.run(Unknown Source) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread.run(Unknown Source) --------------- linked to ------------------ javax.xml.xpath.XPathExpressionException at net.sf.saxon.xpath.XPathExpressionImpl.evaluate(XPathExpressionImpl.java:249) at be.xbrlcore.linkbase.FormulaLinkbase.assertValue(FormulaLinkbase.java:964) at be.xbrlcore.linkbase.FormulaLinkbase$AssertValueCallable.call(FormulaLinkbase.java:2042) at be.xbrlcore.linkbase.FormulaLinkbase$AssertValueCallable.call(FormulaLinkbase.java:1) at java.util.concurrent.FutureTask.run(Unknown Source) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread.run(Unknown Source) Caused by: net.sf.saxon.trans.XPathException: Cannot compare xs:untypedAtomic to xs:date at net.sf.saxon.expr.ValueComparison.compare(ValueComparison.java:735) at net.sf.saxon.expr.ValueComparison.effectiveBooleanValue(ValueComparison.java:695) at net.sf.saxon.xpath.XPathExpressionImpl.evaluate(XPathExpressionImpl.java:202) ... 7 more
Thanks,
Adian Miko
Replies (6)
Please register to reply
RE: Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date - Added by Michael Kay over 7 years ago
The le
operator (a "Value Comparison") always treats an xs:untypedAtomic value as a string. If you want it converted to the type of the other operand, you should use the <=
operator (a "General Comparison") which in XSLT must be written in escaped form as &lt;=
.
Alternatively, you can do the conversion "by hand", by changing the expression to xs:date($v1) le xs:date($v2)
.
RE: Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date - Added by Sergey Yatsenko about 7 years ago
Hello.
I had a similar problem. When I use saxon9-he (version 9.8.0.6) for XPath in an application on Net Framwork, there is an error "net.sf.saxon.trans.XPathException: Can not compare xs: untypedAtomic to xs: decimal".
This occurs when XPathSelector evaluates an expression using the "Evaluate" method. The expression itself looks like this: matches ($ var1 / text (), '^ [0-9] {1,2} . [0-9] {2} $') or ($ var1 eq 100.0).
Variable "var1" is set in XPathSelector by the SetVariable method as XdmNode. The variant of changing the expression is strongly undesirable.
I ask you to suggest a possible way out of this situation.
RE: Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date - Added by Michael Kay about 7 years ago
Same problem, and same solution...
The "=" operator implicitly converts xs:untypedAtomic values to the type of the other operand; the "eq" operator does not.
The reason for this was to give "eq" clean transitive semantics which is needed for building indexes.
I suggest you stick with "eq", but do the conversion explicitly:
xs:decimal($var1) eq 100.0
or use "=" if you prefer:
$var1 = 100.0
RE: Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date - Added by Sergey Yatsenko about 7 years ago
Michael.
Thank you for the detailed response. This helped solve the problem for this case. However, is there really no technical possibility at the Saxon Api level to perform an explicit transformation of the "TypedValue" (xs: untypedAtomic) type "XdmNode" to "DecimalAtomicValue" (as in my example)?
RE: Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date - Added by Michael Kay about 7 years ago
However, is there really no technical possibility at the Saxon Api level to perform an explicit transformation of the "TypedValue" (xs: untypedAtomic) type "XdmNode" to "DecimalAtomicValue" (as in my example)?
There are variious ways you could do this at the Java level. For example
new XdmAtomicValue(xdmNode.getStringValue(), ItemType.DECIMAL);
We've avoided representing all the built-in atomic types as subtypes of XdmAtomicValue, to avoid proliferation of classes, and because on the whole we don't want to encourage people to do things in Java that could be done in XPath/XSLT/XQuery.
RE: Error Evaluting Expression Cannot compare xs:untypedAtomic to xs:date - Added by Sergey Yatsenko about 7 years ago
Now it is clear. Thanks for the answer/
Please register to reply