hibernate查询之原生SQL查询多表

本文介绍了一种使用Hibernate框架实现SQL查询,获取统计信息,并将其映射到自定义JavaBean的方法。包括定义JavaBean、SQL查询语句、使用Hibernate的createSQLQuery方法将结果转化为JavaBean实例的过程。
今天做了统计的需求,框架用的是hibernate.我写了一个sql如下:

String hql="select '事实个数' as statistictype,count(1) as statisticcount from ont_fact UNION" +
" select '实例个数' as statistictype,count(1) as statisticcount from ont_object where object_type_id in (select DISTINCT id from ont_element where element_type = 1) UNION" +
" select '素材个数' as statistictype,count(1) as statisticcount from gs_word UNION" +
" select '素材被引用个数' as statistictype,count(distinct wordId) as statisticcount FROM gs_object_relation where objectId in ( select distinct objectId from ont_fact where objectId is not null and objectId!='') UNION" +
" select '已遴选了的实例个数' as statistictype,count(distinct objectId) as statisticcount from gs_object_relation";

List<StatisticInfo> statisticList=null;

try {
statisticList = userMgService.getStatisticList(hql);
} catch (RuntimeException e1) {
e1.printStackTrace();
}


我定义了一个javaBean,但是无法对此java bean做hibernate映射,但还想通过次查询语句返回List<StatisticInfo>的结果:


package cn.nsl.pojo;

public class StatisticInfo {
//统计类型.
private String statistictype;
//统计个数.
private int statisticcount;

public String getStatistictype() {
return statistictype;
}
public void setStatistictype(String statistictype) {
this.statistictype = statistictype;
}
public int getStatisticcount() {
return statisticcount;
}
public void setStatisticcount(int statisticcount) {
this.statisticcount = statisticcount;
}

}


查询了相关资料之后,发现问题是可解的:
/**
* 获取统计数据.
*/
@Override
public List<StatisticInfo> getStatisticList(String sql) {
return this.getSession().createSQLQuery(sql).setResultTransformer(Transformers.aliasToBean(StatisticInfo.class)).list();
}

利用这种方式可以讲结果转化为你要的javaBean.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值