BigDecimal sumValue = BigDecimal.ZERO;什么作用
时间: 2024-04-30 08:15:50 浏览: 230
BigDecimal sumValue = BigDecimal.ZERO;的作用是将sumValue初始化为0,使用BigDecimal类型来表示一个精确的数值,避免了浮点数运算的精度问题。BigDecimal.ZERO是BigDecimal类的一个静态常量,表示数值0。通过将sumValue初始化为BigDecimal.ZERO,可以确保在后续的计算中,sumValue的初始值为0,方便进行累加或其他数值计算操作。
相关问题
String sql2 = “SELECT as, bs, cs, ds, es, qs FROM b_table”; PreparedStatement stmt2 = conn.prepareStatement(sql2); ResultSet rs2 = stmt2.executeQuery(); BigDecimal as_current = BigDecimal.ZERO; BigDecimal bs_current = BigDecimal.ZERO; BigDecimal cs_current = BigDecimal.ZERO; BigDecimal ds_current = BigDecimal.ZERO; BigDecimal es_current = BigDecimal.ZERO; BigDecimal qs_current = BigDecimal.ZERO; if (rs2.next()) { as_current = rs2.getBigDecimal(“as”); bs_current = rs2.getBigDecimal(“bs”); cs_current = rs2.getBigDecimal(“cs”); ds_current = rs2.getBigDecimal(“ds”); es_current = rs2.getBigDecimal(“es”); qs_current = rs2.getBigDecimal(“qs”); } rs2.close(); stmt2.close();b表里的数据是小数,请问这段代码查出来为什么是null,已知字段类型是varchar,指出原因并改正
这段代码查询出来的结果为null是因为查询出来的数据类型是小数类型,而变量的初始值是字符串类型的,无法将小数类型赋值给字符串类型的变量。要改正这个问题,需要将变量的类型从字符串类型改为BigDecimal类型,代码如下所示:
```
String sql2 = “SELECT as, bs, cs, ds, es, qs FROM b_table”;
PreparedStatement stmt2 = conn.prepareStatement(sql2);
ResultSet rs2 = stmt2.executeQuery();
BigDecimal as_current = BigDecimal.ZERO;
BigDecimal bs_current = BigDecimal.ZERO;
BigDecimal cs_current = BigDecimal.ZERO;
BigDecimal ds_current = BigDecimal.ZERO;
BigDecimal es_current = BigDecimal.ZERO;
BigDecimal qs_current = BigDecimal.ZERO;
if (rs2.next()) {
as_current = rs2.getBigDecimal(“as”);
bs_current = rs2.getBigDecimal(“bs”);
cs_current = rs2.getBigDecimal(“cs”);
ds_current = rs2.getBigDecimal(“ds”);
es_current = rs2.getBigDecimal(“es”);
qs_current = rs2.getBigDecimal(“qs”);
}
rs2.close();
stmt2.close();
```
注意,需要将变量的初始值设置为BigDecimal类型的0,而不是字符串类型的0。
java.math.BigDecimal b1 = new java.math.BigDecimal(Double.toString(v1)); java.math.BigDecimal b2 = new java.math.BigDecimal(Double.toString(v2)); return b1.multiply(b2).doubleValue();将结果改为保留4位小数
好的,您可以使用以下代码来将结果保留4位小数:
```
java.math.BigDecimal b1 = new java.math.BigDecimal(Double.toString(v1));
java.math.BigDecimal b2 = new java.math.BigDecimal(Double.toString(v2));
double result = b1.multiply(b2).doubleValue();
result = (double)Math.round(result * 10000) / 10000;
return result;
```
其中,`result`变量的值即为两个数相乘的结果,经过四舍五入后保留4位小数。
阅读全文