在数据库里通过count()函数查到了两个数据,进行相除的时候爆出异常:java.lang.long can not be cast to java.lang.Integer
在网上查了资料发现是数据库的问题,查出来的是long类型,而long类型是不能直接相除的。
但是又不能直接转换为integer,因为integer和long都是直接继承于父类Number类型,直接转换会报上述异常。
那就从Number下手。
((java.lang.Number) goods.get("favourableCommentNum")).intValue()可以把long类型转换为一个int数据
((java.lang.Number) goods.get("favourableCommentNum")).doubleValue()可以把long类型转换为一个double数据,因为要计算百分比,就需要转换成double类型。
DecimalFormat df = new DecimalFormat("0%");
df.format(((java.lang.Number) goods.get("favourableCommentNum")).intValue()/ ((java.lang.Number) goods.get("commentNum")).doubleValue())就可以算出不带小数点的百分比
DecimalFormat df1 = new DecimalFormat("0.00%");
df1.format(((java.lang.Number) goods.get("favourableCommentNum")).intValue()/ ((java.lang.Number) goods.get("commentNum")).doubleValue())计算出的是带小数点后两位的百分比
版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/qq_33621326/article/details/85011405
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。