Hibernate中关于HQL查询返回List<Object>数据的结果集问题

---恢复内容开始---

开发中遇到的一个小问题,使用Hibernate中的HQL查询时,使用query.list()查询出来的是一个List<Object>结果集

原来代码:

public List findDataByProvince(String yxszsdm, int year) {
StringBuffer sql=new StringBuffer();
sql.append("SELECT * FROM employment_status WHERE sfdm=:sfdm AND year=:year " +
" AND stat_date =(SELECT MAX(stat_date) FROM employment_status)");
logger.info(sql.toString());
Query query=this.getSession().createSQLQuery(sql.toString());
query.setParameter("sfdm",yxszsdm);
query.setParameter("year",year);
List<EmploymentStatus> list=(List<EmploymentStatus>)query.list();
return list;
}

导致出现的问题如下图所示:

 

在代码中,我期望的是 返回一个List<EmploymentStatus> 集合对象,但是返回的是List<Object>,这样接收竟然也不报错,出现的问题就是,字段名少了,变成了0 1 2 3..  ,这样的数据需要我们在重新做处理,显示很麻烦。

修改后代码:

public List<EmploymentStatus> findDataBySchool(String yxszsdm,String yxdm,int year) {
StringBuffer sql=new StringBuffer();
sql.append("SELECT * FROM employment_status WHERE sfdm =:sfdm OR yxdm = :yxdm AND year =:year " +
" AND stat_date =(SELECT MAX(stat_date) FROM employment_status) ");
logger.info(sql.toString());
SQLQuery query=this.getSession().createSQLQuery(sql.toString());
query.setParameter("sfdm",yxszsdm);
query.setParameter("yxdm",yxdm);
query.setParameter("year",year);
query.addEntity(EmploymentStatus.class);
return query.list();
}

在这里需要我们将Query换成SqlQuery,使用其中的sqlQuery.addEntity(EmploymentStatus.class),这样查询出来的结果就是我们想要的对象结果集。

 



---恢复内容结束---

posted @ 2017-12-13 16:23  luckysky  阅读(6669)  评论(0编辑  收藏  举报