Oracle中字段类型为Integer取出来是java.math.BigDecimal

本文记录了一次在Oracle10g数据库中查询Integer类型字段时遇到的类型转换问题。原本期望获得Integer类型的值却得到了BigDecimal类型的数据,导致了类型转换失败。为解决此问题,最终采取了将所有查询结果统一转为String类型的折中方案。

 

今天工作中遇到一个强制类型转换的错误:

 

Oracle 10g数据库,一张表的某个字段是Integer型的,查询数据,将数据封装在Map中,获取出之后,用强制类型转换,报错.

 

....

List result = dao.queryBySql(....);
....

Map map = (Map)rusult.get(i);
System.out.println((Integer)map.get("PID"));
System.out.println((String)map.get("PID"));
//以上两句强制转换都报错,通过异常看,取出的是java.math.BigDecimal

 DB2的Integer取出之后就是一个Integer,由于不想太麻烦,统一使用String来处理了

 

....

List result = dao.queryBySql(....);
....

Map map = (Map)rusult.get(i);
String.valueOf(map.get("PID"));

 String作为一个折中的办法,还是不错的....

 

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值