求帮忙解决java.math.BigDecimal cannot be cast to java.lang.L

wanwang8 2011-01-04 10:55:48
public long searchCount(String beginTime,String endTime){
long countResult = 1L;
String sql = null;
sql = "select count(*) from T_CLIENT t";
s = HibernateUtil.getSession();
countResult = ((Long)s.createSQLQuery(sql).uniqueResult()).longValue();
}
执行到这的时候就报上面错了,long换成int也还是不行,求人指导,急
...全文
23329 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
shanxmxj 2011-01-04
  • 打赏
  • 举报
回复 1
[Quote=引用 2 楼 amos1989 的回复:]
你的数据库里面是BigDecimal类型

你直接强转成Long可以吗? 去google一下.看怎么转型的。

((BigDecimal)s.createSQLQuery(sql).uniqueResult()).longValue()

就OK啦
[/Quote]

+1
psuqqvfp 2011-01-04
  • 打赏
  • 举报
回复
CAINIAOYING 2011-01-04
  • 打赏
  • 举报
回复
先将这个s.createSQLQuery(sql).uniqueResult()转换成String类型然后再转成long
Long.parseLong(s.createSQLQuery(sql).uniqueResult().toString());
tubage408 2011-01-04
  • 打赏
  • 举报
回复 1
((BigDecimal)s.createSQLQuery(sql).uniqueResult()).longValue()
学习Java中 2011-01-04
  • 打赏
  • 举报
回复 1
试下用Number
Number number = ....
number.longValue();
amos1989 2011-01-04
  • 打赏
  • 举报
回复
你的数据库里面是BigDecimal类型

你直接强转成Long可以吗? 去google一下.看怎么转型的。

((BigDecimal)s.createSQLQuery(sql).uniqueResult()).longValue()

就OK啦
dream1210 2011-01-04
  • 打赏
  • 举报
回复
因为你用sql查出来时候是Object类型的数据.
可以用countResult = Long.valueOf(s.createSQLQuery(sql).uniqueResult().toString());

67,512

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧