[ 
https://issues.apache.org/jira/browse/CAY-2805?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Nikita Timofeev closed CAY-2805.
--------------------------------
    Resolution: Fixed

*5.0*: 
https://github.com/apache/cayenne/commit/e77da423b4894cb65d5d5cb2114ae92e9644dbdf
*4.2*: 
https://github.com/apache/cayenne/commit/5c43442140ffbe2d6d2c7dad54f52a868609968e

> Stop calling exp parser internally
> ----------------------------------
>
>                 Key: CAY-2805
>                 URL: https://issues.apache.org/jira/browse/CAY-2805
>             Project: Cayenne
>          Issue Type: Improvement
>    Affects Versions: 4.2.RC2
>            Reporter: Andrus Adamchik
>            Assignee: Nikita Timofeev
>            Priority: Minor
>
> This is a performance optimization suggestion.  Just noticed during profiling 
> a few minor "hotspots" due to calling "ExpressionFactory.exp()" inside the 
> following methods in the Cayenne core:
> * PrefetchProcessorJointNode.buildRowMapping(..)
> * DefaultSelectTranslator.appendQueryColumns(..)
> * SelectQueryMetadata.buildEntityResultForColumn(..)
> This results in exp parser invocation, which is fairly slow. At the same 
> time, in all these places the expression is known to be a path (either DB or 
> OBJ). So we can take a shortcut and apply a faster parsing function to 
> generate ASTObjPath or ASTDbPath.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to