TAJO-2142: Temporarily disable NOT IN subquery.
Closes #1010
diff --git a/CHANGES b/CHANGES
index 4838614..31fbd2a 100644
--- a/CHANGES
+++ b/CHANGES
@@ -254,6 +254,8 @@
TASKS
+ TAJO-2142: Temporarily disable NOT IN subquery. (jihoon)
+
TAJO-2088: Change QueryTestCaseBase.runSimpleTests() to return a set of
TajoResultSetBase. (jihoon)
diff --git a/tajo-core-tests/src/test/java/org/apache/tajo/engine/query/TestInSubquery.java b/tajo-core-tests/src/test/java/org/apache/tajo/engine/query/TestInSubquery.java
index 41c0bd5..9ef84ba 100644
--- a/tajo-core-tests/src/test/java/org/apache/tajo/engine/query/TestInSubquery.java
+++ b/tajo-core-tests/src/test/java/org/apache/tajo/engine/query/TestInSubquery.java
@@ -21,6 +21,7 @@
import org.apache.tajo.IntegrationTest;
import org.apache.tajo.NamedTest;
import org.apache.tajo.exception.NotImplementedException;
+import org.apache.tajo.exception.TajoException;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
@@ -170,4 +171,9 @@
// (select l_partkey from lineitem where l_linenumber in (1, 3, 5, 7, 9))
runSimpleTests();
}
+
+ @Test(expected = NotImplementedException.class)
+ public final void testNotInSubquery() throws TajoException {
+ executeString("select n_name from nation where n_nationkey not in (select r_regionkey from region)");
+ }
}
diff --git a/tajo-plan/src/main/java/org/apache/tajo/plan/rewrite/rules/InSubqueryRewriteRule.java b/tajo-plan/src/main/java/org/apache/tajo/plan/rewrite/rules/InSubqueryRewriteRule.java
index 979c9d7..eb617e6 100644
--- a/tajo-plan/src/main/java/org/apache/tajo/plan/rewrite/rules/InSubqueryRewriteRule.java
+++ b/tajo-plan/src/main/java/org/apache/tajo/plan/rewrite/rules/InSubqueryRewriteRule.java
@@ -22,7 +22,9 @@
import org.apache.tajo.algebra.JoinType;
import org.apache.tajo.catalog.Schema;
import org.apache.tajo.catalog.SchemaUtil;
+import org.apache.tajo.exception.NotImplementedException;
import org.apache.tajo.exception.TajoException;
+import org.apache.tajo.exception.TajoRuntimeException;
import org.apache.tajo.plan.LogicalPlan;
import org.apache.tajo.plan.LogicalPlan.QueryBlock;
import org.apache.tajo.plan.Target;
@@ -113,6 +115,9 @@
// 2. create join
JoinType joinType = eachIn.isNot() ? JoinType.LEFT_ANTI : JoinType.LEFT_SEMI;
+ if (joinType == JoinType.LEFT_ANTI) {
+ throw new TajoRuntimeException(new NotImplementedException("Not-in subquery"));
+ }
JoinNode joinNode = new JoinNode(plan.newPID());
joinNode.init(joinType, baseRelation, subqueryEval.getSubQueryNode());
joinNode.setJoinQual(buildJoinCondition(leftEval, subqueryEval.getSubQueryNode()));