Cognos异常(四) - 计算溢出问题(PDS-PPE-0104)

这里记录个问题,也遇到过,但是怎么解决的忘记了,


原文地址:http://www.cognoschina.net/club/thread-14703-1-1.html

同事通过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,反馈到页面展示的数据默认就是万元单位,在报表页面上也不需要在进行刻度的调整。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值