Petr Masopust created CALCITE-6068:
--------------------------------------

             Summary: Whitespaces are removed from filter values
                 Key: CALCITE-6068
                 URL: https://issues.apache.org/jira/browse/CALCITE-6068
             Project: Calcite
          Issue Type: Bug
    Affects Versions: 1.35.0
            Reporter: Petr Masopust


SqlImplementor.java has hardcoded "true" for trimming whitespaces in
Context.toIn method 
(https://github.com/apache/calcite/blob/c83ac69111fd9e75af5e3615af29a72284667a4a/core/src/main/java/org/apache/calcite/rel/rel2sql/SqlImplementor.java#L908).
 
This makes troubles for our customer who use values like "Value 1 " etc. (don't 
ask me why).
E.g.
val filter = relBuilder.`in`(
opportunityId,
relBuilder.literal("value 1 "),
relBuilder.literal("value 2 ")
)
is translated to "id" IN ('value 1', 'value 2') WITHOUT spaces at the end.
 
I don't know why is such trimming implemented but calcite should not touch user 
inputs. Please make this at least configurable because I don't know any 
workaround. Obvious one with OR and equalities is optimized to IN and trimmed 
too.



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

Reply via email to