From ef67680a55f3b38643c9e485b0736d3066cd2eb4 Mon Sep 17 00:00:00 2001 From: Marc Prud'hommeaux Date: Wed, 17 Jan 2007 21:48:27 +0000 Subject: [PATCH] Fixed concatinate function to cast both sides as a VARCHAR, since DB2 and Derby disallow parameters on both sides of the function. git-svn-id: https://svn.apache.org/repos/asf/incubator/openjpa/trunk@497190 13f79535-47bb-0310-9956-ffa450edef68 --- .../org/apache/openjpa/jdbc/sql/AbstractDB2Dictionary.java | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/AbstractDB2Dictionary.java b/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/AbstractDB2Dictionary.java index 22af396ea..5000e8ac3 100644 --- a/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/AbstractDB2Dictionary.java +++ b/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/AbstractDB2Dictionary.java @@ -31,9 +31,13 @@ public abstract class AbstractDB2Dictionary longVarbinaryTypeName = "BLOB"; varbinaryTypeName = "BLOB"; + // DB2-based databases have restrictions on having uncast parameters + // in string functions toUpperCaseFunction = "UPPER(CAST({0} AS VARCHAR(1000)))"; toLowerCaseFunction = "LOWER(CAST({0} AS VARCHAR(1000)))"; stringLengthFunction = "LENGTH(CAST({0} AS VARCHAR(1000)))"; + concatenateFunction = "(CAST({0} AS VARCHAR(1000)))||" + + "(CAST({1} AS VARCHAR(1000)))"; trimLeadingFunction = "LTRIM({0})"; trimTrailingFunction = "RTRIM({0})";