You are viewing a plain text version of this content. The canonical link for it is here.
Posted to derby-dev@db.apache.org by "Mamta A. Satoor (JIRA)" <ji...@apache.org> on 2012/09/30 04:40:07 UTC

[jira] [Updated] (DERBY-3876) Stack overflow when issuing SELECT statements with *lots* of 'OR' in the WHERE clause

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

Mamta A. Satoor updated DERBY-3876:
-----------------------------------

    Labels: derby_triage10_10  (was: )
    
> Stack overflow when issuing SELECT statements with *lots* of 'OR' in the WHERE clause
> -------------------------------------------------------------------------------------
>
>                 Key: DERBY-3876
>                 URL: https://issues.apache.org/jira/browse/DERBY-3876
>             Project: Derby
>          Issue Type: Improvement
>          Components: SQL
>            Reporter: Øyvind Harboe
>              Labels: derby_triage10_10
>
> The problem is that e.g. Cayenne uses *long* SQL statements with *lots* of OR statements to implement certain operations.
> This causes a stack overflow as evaluation of 'OR' is implemented recursively.
> Could an iterative implementation trivially replace the recursive implementation? 
> at org.apache.derby.impl.sql.compile.OrNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryLogicalOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.OrNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryLogicalOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.OrNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryLogicalOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.OrNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryOperatorNode.bindExpression(Unknown Source)
> at org.apache.derby.impl.sql.compile.BinaryLogicalOpera
> See also
> https://issues.apache.org/cayenne/browse/CAY-1079?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12974#action_12974

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira