`

解决COGNOS交叉表计算溢出问题(PDS-PPE-0104)

 
阅读更多

      通过FM发布的包做一交叉,在查询中的每一步都没出现问题,但最后一个交叉表引用的查询出错下面的错误:
PDS-PPE-0104
A record was rejected. An arithmetic overflow occurred. PDS-PPE-0104 A record was rejected. An arithmetic overflow occurred. (Data)

        原因分析:交叉表报数据溢出错误是因为交叉表默认支持19位数,其中cognos配置默认小数位7为,小数点一位,因此整数最高位为11为,若数据量较大,就会报错误。

        网上资料,都是要把c8_location/configuration/CQEConfig.xml.sample 配置文件修改为 c8_location/configuration/CQEConfig.xml,把其中的“crosstabDecimalPrecision”参数并将该值减小到所需的小数精度。我查了半天也没找到crosstabDecimalPrecision,一看网上这些文章都是抄来抄去,要不就是没有经过验证,要不就是COGNOS版本太低。

        在验证该问题时,发现使用列表时没问题,把其中一列(存款余额本年累积数)去掉也没问题,看来问题出现存款的数太大(能累计出14位长的整数),在交叉表无法暂时。

        问题找到,解决其实很简单,在查询中把【存款余额本年累积数】先除10000,在报表展示时去掉刻度的-4。呵呵,搞定。既然数太大,那我就先除10000,反馈到页面展示的数据默认就是万元单位,在报表页面上也不需要在进行刻度的调整。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics