Expand my Community achievements bar.

Don’t miss the AEM Skill Exchange in SF on Nov 14—hear from industry leaders, learn best practices, and enhance your AEM strategy with practical tips.
SOLVED

Child Node Iterating

Avatar

Level 4

which is the fastest and better way to find out all the "stepitem" nodes from the following structure? Currently, I am using Querybuilder to list down all the step-item node below the page, but is it the fastest way or list children method of Resource Api is fastest.

Screenshot 2019-09-06 at 4.04.01 PM.png

1 Accepted Solution

Avatar

Correct answer by
Employee Advisor

The query is not always faster. Your query very likely searches the index with the wildcard filter "stepsitem__%" (should not be that expensive) and finds ALL nodes with that name, performs a path lookup in the repo (unless the path is also part of that index), and then filters the result according to ACL etc. Depending on the amount of "stepsitem_%" nodes in the repo, your query might load thousands of potential hits which are then eliminated by the path filter. The runtime performance might vary.

If you iterate through a few hundreds nodes (which is very likely the case if you just search the nodes below a single cq:pageContent node), the iteration is probably much faster, because it does less IO.

You should benchmark it, but then use a timer with a nanosecond resolution, miliseconds is probably not fine enough.

Jörg

View solution in original post

3 Replies

Avatar

Level 5

hi

You can use the node iterator or can be refactored using Sling API or third method is slingquery .

The Sling and AEM API both do the same thing with far less code and without any exceptions.

The AEM API has the added benefit that the developer doesn’t need to know about the inner structure of what a property is named or where it’s saved. If the property would be stored in the property ‘title’ in the next version, none of your code would need to change!

My personal guideline is to use the higher-level API’s when you can. Only when you need a feature that isn’t available higher up, should you switch to the lower-level API.

thnkz

Avatar

Community Advisor

JCR Queries are always faster becuase they uses index unlike Sling API and Sling Query

you can use SQL2 query to achieve same

e.g.

SELECT * FROM [nt:unstructured] AS node

WHERE ISDESCENDANTNODE(node, "/content/site/page")

AND NAME() like "stepsitem_%"



Arun Patidar

Avatar

Correct answer by
Employee Advisor

The query is not always faster. Your query very likely searches the index with the wildcard filter "stepsitem__%" (should not be that expensive) and finds ALL nodes with that name, performs a path lookup in the repo (unless the path is also part of that index), and then filters the result according to ACL etc. Depending on the amount of "stepsitem_%" nodes in the repo, your query might load thousands of potential hits which are then eliminated by the path filter. The runtime performance might vary.

If you iterate through a few hundreds nodes (which is very likely the case if you just search the nodes below a single cq:pageContent node), the iteration is probably much faster, because it does less IO.

You should benchmark it, but then use a timer with a nanosecond resolution, miliseconds is probably not fine enough.

Jörg