[teiid-issues] [JBoss JIRA] (TEIID-5345) ClassCastException if criteria column is derived from case statement
Debbie Steigner (JIRA)
issues at jboss.org
Fri May 18 07:36:00 EDT 2018
Debbie Steigner created TEIID-5345:
--------------------------------------
Summary: ClassCastException if criteria column is derived from case statement
Key: TEIID-5345
URL: https://issues.jboss.org/browse/TEIID-5345
Project: Teiid
Issue Type: Bug
Components: Query Engine
Affects Versions: 8.12.12.6_4
Reporter: Debbie Steigner
Assignee: Steven Hawkins
Select without criteria returns - select * from XXX_LOC_EDL.LOC_BNDRY, If adding criteria on BNDRY_CD it fails with ClassCastException[1]. I assume it's because on some sources the BNDRY_CD is derived by a case statement[2].
[1]
ERROR [org.teiid.PROCESSOR] (Worker133_QueryProcessorQueue5109) TEIID30019 Unexpected exception for request Zplru34y5LCX.5: java.lang.ClassCastException: org.teiid.query.sql.symbol.Constant cannot be cast to org.teiid.query.sql.symbol.Array
at org.teiid.query.optimizer.relational.rules.CriteriaCapabilityValidatorVisitor$1.visit(CriteriaCapabilityValidatorVisitor.java:894) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.sql.lang.DependentSetCriteria.acceptVisitor(DependentSetCriteria.java:161) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.rules.CriteriaCapabilityValidatorVisitor.canPushLanguageObject(CriteriaCapabilityValidatorVisitor.java:957) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.rules.CriteriaCapabilityValidatorVisitor.canPushLanguageObject(CriteriaCapabilityValidatorVisitor.java:861) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.rules.RuleRaiseAccess.canRaiseOverSelect(RuleRaiseAccess.java:512) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.rules.RulePushSelectCriteria.examinePath(RulePushSelectCriteria.java:442) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.rules.RulePushSelectCriteria.pushTowardOriginatingNode(RulePushSelectCriteria.java:353) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.rules.RulePushSelectCriteria.execute(RulePushSelectCriteria.java:116) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.RelationalPlanner.executeRules(RelationalPlanner.java:932) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.relational.RelationalPlanner.optimize(RelationalPlanner.java:228) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.query.optimizer.QueryOptimizer.optimizePlan(QueryOptimizer.java:159) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.Request.generatePlan(Request.java:448) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.Request.processRequest(Request.java:476) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.RequestWorkItem.processNew(RequestWorkItem.java:642) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.RequestWorkItem.process(RequestWorkItem.java:337) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.AbstractWorkItem.run(AbstractWorkItem.java:51) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.RequestWorkItem.run(RequestWorkItem.java:274) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.DQPWorkContext.runInContext(DQPWorkContext.java:284) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.ThreadReuseExecutor$RunnableWrapper.run(ThreadReuseExecutor.java:119) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at org.teiid.dqp.internal.process.ThreadReuseExecutor$3.run(ThreadReuseExecutor.java:210) [teiid-engine-8.12.12.6_4-redhat-64-2.jar:8.12.12.6_4-redhat-64-2]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) [rt.jar:1.8.0_171]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) [rt.jar:1.8.0_171]
at java.lang.Thread.run(Thread.java:748) [rt.jar:1.8.0_171]
[2]
SELECT_CRITERIA=CASE WHEN (LENGTH(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code) < 2) AND (LENGTH(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code) < 2) THEN CONCAT(LPAD(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code, 2, '0'), LPAD(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code, 2, '0')) WHEN (LENGTH(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code) < 2) AND (LENGTH(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code) >= 2) THEN CONCAT(LPAD(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code, 2, '0'), RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code) WHEN (LENGTH(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code) >= 2) AND (LENGTH(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code) < 2) THEN CONCAT(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code, LPAD(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code, 2, '0')) ELSE CONCAT(RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.Prov_Code, RDS_PH_APPS_IMSMasterfiles_DS.UNICUST.City_Code) END = '66131'
--
This message was sent by Atlassian JIRA
(v7.5.0#75005)
More information about the teiid-issues
mailing list