From 3f3d586c7301b1f2f926fb40fac194b6229d970e Mon Sep 17 00:00:00 2001 From: Fay Wang Date: Thu, 3 Dec 2009 23:42:00 +0000 Subject: [PATCH] OPENJPA-1413: fix NPE when update using CASE expression on Derby git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@886991 13f79535-47bb-0310-9956-ffa450edef68 --- .../kernel/exps/CompareEqualExpression.java | 3 ++- .../TestJPQLScalarExpressions.java | 23 ++++++++----------- 2 files changed, 12 insertions(+), 14 deletions(-) diff --git a/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/kernel/exps/CompareEqualExpression.java b/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/kernel/exps/CompareEqualExpression.java index e587a6666..efe1ba3fd 100644 --- a/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/kernel/exps/CompareEqualExpression.java +++ b/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/kernel/exps/CompareEqualExpression.java @@ -106,7 +106,8 @@ abstract class CompareEqualExpression boolean val2Null = _val2 instanceof Const && ((Const) _val2).isSQLValueNull(sel, ctx, bstate.state2); appendTo(sel, ctx, bstate, buf, val1Null, val2Null); - sel.append(buf, state.joins); + if (sel != null) + sel.append(buf, state.joins); } public void selectColumns(Select sel, ExpContext ctx, ExpState state, diff --git a/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/jpql/expressions/TestJPQLScalarExpressions.java b/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/jpql/expressions/TestJPQLScalarExpressions.java index 8256a3bb9..8c884949a 100644 --- a/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/jpql/expressions/TestJPQLScalarExpressions.java +++ b/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/jpql/expressions/TestJPQLScalarExpressions.java @@ -249,22 +249,19 @@ public class TestJPQLScalarExpressions extends AbstractTestCase { assertEquals("the name is not Jacob", "Jacob", result3[0]); assertEquals("the credit rating is not 'POOR'", "POOR", result3[1]); - /* - // this jpql fail with NPE in Derby. It works with DB2 String update2 = "update CompUser c set c.creditRating = " + " CASE WHEN c.name ='Jacob' THEN " + - "org.apache.openjpa.persistence.common.apps.CompUser$ - CreditRating.POOR" + + "org.apache.openjpa.persistence.common.apps.CompUser$CreditRating.POOR" + " WHEN c.name = 'Ugo' THEN " + - "org.apache.openjpa.persistence.common.apps.CompUser$ - CreditRating.GOOD " + + "org.apache.openjpa.persistence.common.apps.CompUser$CreditRating.GOOD " + " ELSE " + - "org.apache.openjpa.persistence.common.apps.CompUser$ - CreditRating.EXCELLENT " + + "org.apache.openjpa.persistence.common.apps.CompUser$CreditRating.EXCELLENT " + " END "; - */ + int updateCount = em.createQuery(update2).executeUpdate(); + assertEquals("the result is not 6", 6, updateCount); - String update2 = "update CompUser c set c.creditRating = " + + + String update3 = "update CompUser c set c.creditRating = " + " CASE WHEN c.age > 30 THEN " + "org.apache.openjpa.persistence.common.apps." + "CompUser$CreditRating.POOR" + @@ -275,7 +272,7 @@ public class TestJPQLScalarExpressions extends AbstractTestCase { "org.apache.openjpa.persistence.common.apps." + "CompUser$CreditRating.EXCELLENT " + " END "; - int updateCount = em.createQuery(update2).executeUpdate(); + updateCount = em.createQuery(update3).executeUpdate(); assertEquals("the result is not 6", 6, updateCount); String query4 = "select e.name, e.creditRating from CompUser e " + @@ -300,7 +297,7 @@ public class TestJPQLScalarExpressions extends AbstractTestCase { ((org.apache.openjpa.persistence.common.apps.CompUser.CreditRating) result4[1]).name()); - String update3 = "update CompUser c set c.creditRating = " + + String update4 = "update CompUser c set c.creditRating = " + " CASE c.age WHEN 35 THEN " + "org.apache.openjpa.persistence.common.apps." + "CompUser$CreditRating.POOR" + @@ -311,7 +308,7 @@ public class TestJPQLScalarExpressions extends AbstractTestCase { "org.apache.openjpa.persistence.common.apps." + "CompUser$CreditRating.EXCELLENT " + " END "; - result = em.createQuery(update3).executeUpdate(); + result = em.createQuery(update4).executeUpdate(); assertEquals("the result is not 6", 6, result); // Derby fails but DB2 works