One problem is that since all columns in a collection are varchars (strings), the built-in aggregation feature of Interactive Reports does not work (it only allows you to aggregate on numbers, which is quite sensible, I guess). Normally you could always convert the string column to a number directly in the underlying query, but since my queries were dynamic (the whole point of using collections), that was not an option.
However, after some fiddling around I discovered that you can aggregate based on computed columns.
So, let's say we have this "transaction amount" column in our report, which consists of numbers but which Apex interprets as a string since it is retrieved from a varchar2 column in the apex_collections view:
data:image/s3,"s3://crabby-images/317d0/317d05e353042b3371a433a8098125103d459e54" alt=""
Use the "Compute" menu item of the Interactive Report to create a new column, using the TRUNC function (for some reason, the TO_NUMBER function is not available from the list of functions, but TRUNC works -- just remember to include the number of decimals as the second parameter if you need decimals) and setting the appropriate numeric format mask:
data:image/s3,"s3://crabby-images/6c65d/6c65dc7cc1a3c882aafa4551380fad62e56d9e57" alt=""
We can now see that the new column has been added as a numeric column, since it is right-aligned instead of left-aligned (and also with a nice format mask):
data:image/s3,"s3://crabby-images/c65a3/c65a3e21baadb516e7433f959d089736ffd33aac" alt=""
The new column is now available under the "Aggregate" menu item of the Interactive Report, so we can create a Sum of the numbers:
data:image/s3,"s3://crabby-images/a6d63/a6d6345eb64e8f1a7ba14822abd1ffb41a1285a0" alt=""
After adding a "Control Break" to the report, we can see that the aggregation works:
data:image/s3,"s3://crabby-images/78f9a/78f9a6c30d79c6dec931595e0f1e443c40ba9be9" alt=""
Did I mention that I really like Interactive Reports? :-)
1 comment:
that's beautiful but how to get rid of the first column?
Cheers, Denis
Post a Comment