[ 
https://issues.apache.org/jira/browse/CALCITE-2636?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16660217#comment-16660217
 ] 

Julian Hyde commented on CALCITE-2636:
--------------------------------------

Here is a test case and proposed fix: 
https://github.com/julianhyde/calcite/tree/2636-quadratic-parser. [~gian], can 
you please review.

> SQL parser has quadratic running time when SQL string is very large
> -------------------------------------------------------------------
>
>                 Key: CALCITE-2636
>                 URL: https://issues.apache.org/jira/browse/CALCITE-2636
>             Project: Calcite
>          Issue Type: Bug
>            Reporter: Julian Hyde
>            Assignee: Julian Hyde
>            Priority: Major
>
> SQL parser has quadratic running time when SQL string is very large.
> This is due to {{SimpleCharStream.ExpandBuff(boolean)}} increasing the buffer 
> in increments of 2,048 (2k) chars. If the SQL string is, say, 1,024k 
> characters, then it will re-alloc at size 2k, 4k, 6k, ...,  1023k, and each 
> time copy the whole string.
> This issue was discovered by [~gian].



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to