OPENJPA-2149: Criteria.function adds wrong casts to parameters making it unusable

git-svn-id: https://svn.apache.org/repos/asf/openjpa/branches/2.0.x@1376089 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Jody Grassel 2012-08-22 15:08:16 +00:00
parent e11755e4b4
commit f8171ddd32
3 changed files with 21 additions and 10 deletions

View File

@ -171,11 +171,17 @@ public class Args
return 0;
}
public void appendTo(Select sel, ExpContext ctx, ExpState state,
SQLBuffer sql, int index) {
public void appendTo(Select sel, ExpContext ctx, ExpState state, SQLBuffer sql, int index) {
appendTo(sel, ctx, state, sql, index, null);
}
public void appendTo(Select sel, ExpContext ctx, ExpState state, SQLBuffer sql, int index, String operator) {
ArgsExpState astate = (ArgsExpState) state;
for (int i = 0; i < _args.length; i++) {
_args[i].appendTo(sel, ctx, astate.states[i], sql, index);
if( operator != null ) {
sql.addCastForParam(operator, _args[i]);
}
if (i < _args.length-1)
sql.append(", ");
}

View File

@ -46,16 +46,12 @@ public class DatastoreFunction extends UnaryOp {
public void appendTo(Select sel, ExpContext ctx, ExpState state,
SQLBuffer sql, int index) {
Args args = (Args) getValue();
if (!ctx.store.getDBDictionary().requiresCastForMathFunctions || args.getValues().length == 1)
if (!ctx.store.getDBDictionary().requiresCastForMathFunctions || args.getValues().length == 1) {
super.appendTo(sel, ctx, state, sql, index);
else {
} else {
sql.append(getOperator());
sql.append("(");
args.appendTo(sel, ctx, state, sql, 0);
Val[] vals = args.getVals();
for (int i = 1; i < vals.length; i++) {
sql.addCastForParam(getOperator(), vals[i]);
}
args.appendTo(sel, ctx, state, sql, 0, getOperator());
sql.append(")");
}
}

View File

@ -139,7 +139,16 @@ abstract class UnaryOp
sql.append(getOperator());
sql.append(_noParen ? " " : "(");
_val.appendTo(sel, ctx, state, sql, 0);
sql.addCastForParam(getOperator(), _val);
// OPENJPA-2149: If _val (Val) is an 'Arg', we need to get the Val[]
// from it, and the single element it contains because the
// 'addCastForParam' method gets the 'type' from the Val it receives.
// In the case where _val is an Arg, when addCastForParam gets the
// type, it will be getting the type of the Val (an Object) rather
// the type of the Arg.
sql.addCastForParam(getOperator(),
(_val instanceof Args) ? (((Args) _val).getVals())[0]
: _val);
if (!_noParen)
sql.append(")");
}