在网上查了资料发现是数据库的问题,查出来的是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())计算出的是带小数点后两位的百分比