时间:2021-07-01 10:21:17 帮助过:2人阅读
BigDecimal : Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处 理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用 java.math.BigDecimal。
当从数据库中取出的数是BigDecimal,需要对数据进行BigDecimal造型,然后调用相关方法,取得值,常见方法doubleValue(),intValue()。String类型可以直接造型
Double AVL_AMOUNT_ = ((BigDecimal) matYearPlanSum.get("AMOUNT_")).doubleValue();
(String) matMonthPlan.get("MAT_DESC_")
而如果是自己对取得的数据再进行计算获得新值时,从Map里取就不需要再使用BigDecimal,而是使用自己为其设定的类型
1 for (Map<String, Object> matYearPlanSum : matYearPlanSumList) { 2 AVL_AMOUNT_ = ((BigDecimal) matYearPlanSum.get("AMOUNT_")).doubleValue(); 3 matYearPlanSum.put("AVL_AMOUNT_", AVL_AMOUNT_); 4 for (Map<String, Object> matMonthPlanHis : matDeptMonthPlanSpentBudget) { 5 if (matYearPlanSum.get("MAT_NO_").equals(matMonthPlanHis.get("MAT_NO_"))) { 6 if (matYearPlanSum.get("AMOUNT_") != null && matMonthPlanHis.get("SPENT_AMOUNT_") != null) { 7 AVL_AMOUNT_ = ((BigDecimal) matYearPlanSum.get("AMOUNT_")).doubleValue() - ((BigDecimal) matMonthPlanHis.get("SPENT_AMOUNT_")).doubleValue(); 8 } 9 matYearPlanSum.put("AVL_AMOUNT_", AVL_AMOUNT_); 10 break; 11 } 12 } 13 } 14 for (Map<String, Object> matMonthPlan : matMonthPlanList) { 15 for (Map<String, Object> matYearPlanSum : matYearPlanSumList) { 16 if (matMonthPlan.get("MAT_NO_").equals(matYearPlanSum.get("MAT_NO_"))) { 17 if (matYearPlanSum.get("ENABLE_AMOUNT_") != null && matMonthPlan.get("AMOUNT_") != null) { 18 ENABLE_AMOUNT_ = ((BigDecimal) matMonthPlan.get("AMOUNT_")).doubleValue(); 19 ENABLE_AMOUNT_ = (Double) matYearPlanSum.get("ENABLE_AMOUNT_") + ENABLE_AMOUNT_;//例如此处的Double 20 } 21 matMonthPlan.put("ENABLE_AMOUNT_", ENABLE_AMOUNT_); 22 break; 23 } 24 } 25 }
常见报错:Caused by: java.sql.SQLException: ORA-00911: 无效字符 是因为拼接的SQL语句后面多了一个分号。使用spring jdbctemplate不需要在SQL语句后加分号
to_date() 作用将字符类型按一定格式转化为日期类型:
具体用法:to_date(‘‘2004-11-27‘‘,‘‘yyyy-mm-dd‘‘),前者为字符串,后者为转换日期格式,注意,前后两者要以一对应。
如;to_date(‘‘2004-11-27 13:34:43‘‘, ‘‘yyyy-mm-dd hh24:mi:ss‘‘) 将得到具体的时间
jdbctemplate中的批量更新使用,BigDecimal与造型的联系和区别
标签: