Showing results for 
Search instead for 
Did you mean: 

Error in business rule

New Contributor


Can anybody help with this error? what we need to check for this in business rule. 







Hi, the issue is that your business rule CG_StatisticalCalcs tries to put a value in a parameter/ datatable/ object where the type of Decimal is expected. However the number that is processes is too big to fit in the Decimal specifications.

Decimal is already very big 28 to 29 significant digits, so i would suggest investigating your data where this very large number is comming from.

Marc Roest
OneStream consultant @Finext

Valued Contributor

With, it is possible to calculate with larger number than what the datatype decimal allows you to do, by using floating point data types (single and double). Of cause, to store it back to Onestream, it needs to fit to a decimal datatype. But if only the intermediate results are to big something like this will work:

Dim scriptS As String = "..."
Dim scriptT As String = "..."

Dim number1 As Double = 'i.e. 1000000000000000000
Dim number2 As Double = 'i.e. 1000000000000000000
Dim number3 As Double = 'i.e. 1000000000000000000

Dim result As Double = number1 * number2 / number3
Dim resultDec As Decimal = result

api.Data.SetDataCell(scriptT, resultDec, False)

So, if your calculation only fails, because it has problems with intermediate results (and with statistics this is possible), but the final result are in the range of a decimal, you can calculate it like this.

Be aware, like in Excel, scientific notification looses precision the larger a number gets, so it might not be 100% correct (That's the reason, we are using decimals instead of floats).

New Contributor

Hi, try to check that the variable which stores the value in your business rule is declared as decimal.