最近遇到两次在hql的in中传递参数的问题,最初让我纠结万千。
在dao层已经封装好了一个使用hql获取数据的方法:
public List<?> findByHql(String hql, Map<String, Object> map, int pageSize,int pageNo) {
return this.getQuery(hql, map, pageSize, pageNo).list();
}
private Query getQuery(String hql, Map<String, Object> map, int pageSize,int pageNo) {
Query query = this.createQuery(hql);
query = this.setParameter(query, map);
query = this.setPageProperty(query, pageSize, pageNo);
return query;
}
private Query createQuery(String hql) {
return getSession().createQuery(hql);
}
private Query setParameter(Query query, Map<String, Object> map) {
if (map != null) {
Set<String> keySet = map.keySet();
for (String string : keySet) {
Object obj = map.get(string);
query.setParameter(string, map.get(string));
}
}
return query;
}
private Query setPageProperty(Query query, int pageSize, int pageNo) {
if (pageNo != 0 && pageSize != 0) {
query.setFirstResult((pageNo - 1) * pageSize);
query.setMaxResults(pageSize);
}
return query;
}
通常在业务层只需要写相应的hql,然后把对应参数封装到map中,即可查询出自己需要的数据。
然后我有这样一句查询语句:
String hql = "FROM Login login WHERE login.id in(:ids)";
Map<String,Object> map = new HashMap<String,Object>();
Integer[] ids = new Integer[]{1,2,3};
map.put("ids",ids);
List<Login> lstLogin = (List<Login>)xxxDao.findByHql(hql,map,0,0);
最后运行的时候,发生异常:ljava.lang.Integer cannot be cast to java.lang.Integer
也就是说hibernate把ids这个参数当做一个Integer对象了而不是一个集合。
后来在网上找了下答案,原来对hibernate中setParameter这个方法还不熟悉:Query接口提供了多种传递参数的方法,可以是传单独参数,也可以传集合,如下图
也就是说,前面使用数组集合的话则必须调用setParameterList方法。
那么改一下Dao层的setParameter方法即可达到通用了:
private Query setParameter(Query query, Map<String, Object> map) {
if (map != null) {
Set<String> keySet = map.keySet();
for (String string : keySet) {
Object obj = map.get(string);
//这里考虑传入的参数是什么类型,不同类型使用的方法不同
if(obj instanceof Collection<?>){
query.setParameterList(string, (Collection<?>)obj);
}else if(obj instanceof Object[]){
query.setParameterList(string, (Object[])obj);
}else{
query.setParameter(string, obj);
}
}
}
return query;
}
最初还以为是hibernate不够智能化,原来是自己没学好,项目经验相当重要呀...
- 大小: 39.1 KB
分享到:
相关推荐
Hibernate框架]Hql语句in中带参数的写法
hibernate-HQL语句大全
Hibernate 多对多HQL语句写法
hibernate 中HQL语句查询学习笔记
hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全hql语句大全
HQL语句大全HQL语句大全HQL语句大全HQL语句大全HQL语句大全
Hibernate中HQL语句的使用[参考].pdf
HQL的全称是?...HQL语句为:select jd.jdid,jd.jd from TblJd jd。怎样获得并显示查询结果? 使用'?'做占位符的参数查询,怎样设置参数的值? 命名参数查询的语法是? 怎样创建Criteria查询对象?
HQL语句 HQL语句 HQL语句 HQL语句 HQL语句
weblogic12 下最新 org.hibernate.hql.ast.HqlToken解决办法
hibernate查询之HQLhibernate查询之HQLhibernate查询之HQL
hibernate hql语句 hql语言汇总
让你更好的理解SSH开发的运营。更好的调用数据
Hibernate案例与专题-HQL语句。详细介绍了HibernateHQL语句。
对Hibernate中HQL语句的讲解
Hibernate HQL查询语句总结.docx 网络下载的
hibernate的HQL语句,基本与复杂都包括,单表查询等语句和多表的关联语句
Hibernate HQL基础练习小列子+数据库
对hibernate的hql进行了详尽的讲解
Hibernate hql查询语法总结 Hibernate hql查询语法总结