Hibernate-hibernate 中 Long 与 int 的转换
2016-12-11 21:44
316 查看
hibernate 中使用聚合函数 count 查询记录数时,返回值类型为 Long ,若强行转换则会出现 java.lang.ClassCastException 异常,
正确写法应使用 Number 类型作为过渡则不会出错。
错误写法:
@Override
public int findCountByCid(Integer cid) {
String hql = "SELECT count(*) from Product p WHERE p.categorySecond.category.cid = ?";
Query query = getSession().createQuery(hql).setInteger(0, cid);
List<Integer> list = query.list();//返回值类型应为 Long 强行转换 Integer
int result = list.get(0);//调用将会出现异常
return result;
}
更正后:
@Override
public int findCountByCid(Integer cid) {
String hql = "SELECT count(*) from Product p WHERE p.categorySecond.category.cid = ?";
Query query = getSession().createQuery(hql).setInteger(0, cid);
List<Long> list = query.list();//修正部分
int result = ((Number)list.get(0)).intValue();//修正部分
return result;
}
正确写法应使用 Number 类型作为过渡则不会出错。
错误写法:
@Override
public int findCountByCid(Integer cid) {
String hql = "SELECT count(*) from Product p WHERE p.categorySecond.category.cid = ?";
Query query = getSession().createQuery(hql).setInteger(0, cid);
List<Integer> list = query.list();//返回值类型应为 Long 强行转换 Integer
int result = list.get(0);//调用将会出现异常
return result;
}
更正后:
@Override
public int findCountByCid(Integer cid) {
String hql = "SELECT count(*) from Product p WHERE p.categorySecond.category.cid = ?";
Query query = getSession().createQuery(hql).setInteger(0, cid);
List<Long> list = query.list();//修正部分
int result = ((Number)list.get(0)).intValue();//修正部分
return result;
}
相关文章推荐
- Hibernate Oracle sequence的使用技巧
- jsp Hibernate批量更新和批量删除处理代码
- jsp hibernate的分页代码第1/3页
- Struts2+Hibernate实现数据分页的方法
- Hibernate环境搭建与配置方法(Hello world配置文件版)
- JAVA+Hibernate 无限级分类
- SSH整合中 hibernate托管给Spring得到SessionFactory
- jsp hibernate 数据保存操作的原理
- hibernate中的增删改查实现代码
- 解决hibernate+mysql写入数据库乱码
- java优化hibernate性能的几点建议
- java Hibernate延迟加载
- hibernate 常用方法介绍
- 详解Java的Hibernate框架中的注解与缓存
- 浅析Java的Hibernate框架中的继承关系设计
- Java的Hibernate框架中的继承映射学习教程
- Hibernate实现批量添加数据的方法
- Hibernate4在MySQL5.1以上版本创建表出错 type=InnDB
- JQuery+Ajax+Struts2+Hibernate框架整合实现完整的登录注册
- SSH框架网上商城项目第16战之Hibernate二级缓存处理首页热门显示