The implementation of getReturnType in org.hibernate.dialect.function.StandardAnsiSqlAggregationFunctions.SumFunction ignores custom user types, instead falling back to the underlying JDBC type code. Worse still, a user type with a jdbcType of DECIMAL results in a type for the sum aggregation of double.
We have a Money type, and a corresponding MoneyUserType which converts between java Money instances and database decimal columns. In hibernate 3.2.5, if amount was a Money property, Projections.sum(amount) would return a Money instance. As of 3.6.10, it returns a double.
At bare minimum, sum in this case should return an instance of BigDecimal, so as to avoid the usaual problems of doing floating point arithmetic with monetary amounts. Ideally, it should continue to use the user type of the summed column.
|