[
https://issues.apache.org/jira/browse/CALCITE-2109?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17939210#comment-17939210
]
Caican Cai commented on CALCITE-2109:
-------------------------------------
thanks [~tuichenchuxin],fixd in
https://github.com/apache/calcite/commit/e3184180ba170827e0e91682a693cd02b46b8657
> Mongo adapter: unable to translate (A AND B) conditional case
> -------------------------------------------------------------
>
> Key: CALCITE-2109
> URL: https://issues.apache.org/jira/browse/CALCITE-2109
> Project: Calcite
> Issue Type: Bug
> Components: mongodb-adapter
> Reporter: Vladimir Dolzhenko
> Assignee: Chuxin Chen
> Priority: Major
> Labels: pull-request-available
>
> Mongo adapter fails on query
> {code:sql}
> select state, city from zips
> where city='MANSFIELD' and state in ('AR', 'TX', 'MA')
> order by state
> {code}
> with
> {code}
> java.lang.AssertionError: cannot translate OR(=(CAST(ITEM($0,
> 'state')):VARCHAR(2) CHARACTER SET "ISO-8859-1" COLLATE
> "ISO-8859-1$en_US$primary", 'AR'), =(CAST(ITEM($0, 'state')):VARCHAR(2)
> CHARACTER SET "ISO-8859-1" COLLATE "ISO-8859-1$en_US$primary", 'TX'),
> =(CAST(ITEM($0, 'state')):VARCHAR(2) CHARACTER SET "ISO-8859-1" COLLATE
> "ISO-8859-1$en_US$primary", 'MA'))
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateMatch2(MongoFilter.java:181)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateAnd(MongoFilter.java:116)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateOr(MongoFilter.java:98)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateMatch(MongoFilter.java:91)
> {code}
> literal case like
> {code:sql}
> select state, city from zips
> where city='MANSFIELD' and 1=0
> order by state
> {code}
> fails with
> {code}
> java.lang.AssertionError: cannot translate op null call =(1, 0)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateBinary(MongoFilter.java:198)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateMatch2(MongoFilter.java:169)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateAnd(MongoFilter.java:116)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateOr(MongoFilter.java:98)
> at
> org.apache.calcite.adapter.mongodb.MongoFilter$Translator.translateMatch(MongoFilter.java:91)
> {code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)