[XSL-LIST Mailing List Archive Home] [By Thread] [By Date] [Recent Entries] [Reply To This Message]

Re: Which is faster: count(/Document/A/B) eq 1 ... or

Subject: Re: Which is faster: count(/Document/A/B) eq 1 ... or ... /Document/A/(count(B) eq 1) ?
From: David Carlisle <davidc@xxxxxxxxx>
Date: Wed, 19 Sep 2012 15:07:11 +0100
Re:  Which is faster: count(/Document/A/B) eq 1 ... or
On 19/09/2012 14:34, Costello, Roger L. wrote:
Is there an XPath expression, besides the ones listed, that is even better and faster?


You want to avoid count() as then you are relying on the optimiser to rewrite it away. If you go count(B) eq 1 then unless the optimiser spots this it may try to calculate count(B) which would mean processing the full list of elements.

B and not(B[2])

similarly may be read as evaluating the full list of B elements and then taking the 2nd but it is much more likely the optimiser detects [2] predicates to abort the construction of the sequence at the second item.

David


-- google plus: https:/profiles.google.com/d.p.carlisle

________________________________________________________________________
The Numerical Algorithms Group Ltd is a company registered in England
and Wales with company number 1249803. The registered office is:
Wilkinson House, Jordan Hill Road, Oxford OX2 8DR, United Kingdom.

This e-mail has been scanned for all viruses by Star. The service is
powered by MessageLabs. ________________________________________________________________________


Current Thread

PURCHASE STYLUS STUDIO ONLINE TODAY!

Purchasing Stylus Studio from our online shop is Easy, Secure and Value Priced!

Buy Stylus Studio Now

Download The World's Best XML IDE!

Accelerate XML development with our award-winning XML IDE - Download a free trial today!

Don't miss another message! Subscribe to this list today.
Email
First Name
Last Name
Company
Subscribe in XML format
RSS 2.0
Atom 0.3
Site Map | Privacy Policy | Terms of Use | Trademarks
Free Stylus Studio XML Training:
W3C Member
Stylus Studio® and DataDirect XQuery ™are products from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2013 All Rights Reserved.