Hibernate SQLquery.addEntity

获取多个实体关联查询,封闭到对象

一、Hibernate Query查询部分属性

select new com.golf.back.dto.video.VideFavourDetailDto(v.id, v.thumb, v.videoName, v.videoUrl, v.orgUrl, v.orgUrlSmall, vc.catName, vc.parentId, v.summary, v.content, v.price,v.isFree, v.lookFront, vf.createTime) from VideoFavour vf,Video v ,VideoCat vc where vf.videoId=v.id and v.catId=vc.id 

 VideFavourDetailDto类添加相同参数类型及个数的实例化对象;

二、多表查询,返回多个实体

StringBuffer sql = new StringBuffer("select {vpl.*}, {v.*}, {vc.*} from zg_video_playlog vpl ");
sql.append("left join zg_video v on vpl.video_id=v.id ");
sql.append("left join zg_video_cat vc  on vc.id=v.cat_id ");
sql.append("group by vpl.video_id ");
sql.append("order by vpl.id desc");
Query query = super.getSession().createSQLQuery(sql.toString())
					.addEntity( "vpl" , VideoPlayLog.class )
					.addEntity( "v" , Video.class )
					.addEntity("vc", VideoCat.class);
query.setFirstResult(startPos);
query.setMaxResults(pageSize);
List<Object[]> list = query.list();  
List<VideFavourDetailDto> vdList = new ArrayList<VideFavourDetailDto>();
if(null!=list && list.size()>0){
	VideFavourDetailDto dto = null;
	VideoPlayLog vpl = null;
	Video v = null;
	VideoCat vc = null;
	for(int i=0; i<list.size(); i++){
		vpl = (VideoPlayLog)list.get(i)[0];
		v = (Video)list.get(i)[1];
		vc = (VideoCat)list.get(i)[2];
		dto = new VideFavourDetailDto(vpl.getId(), v.getId(), v.getThumb(), v.getVideoName(), 
				v.getVideoUrl(), v.getOrgUrl() , v.getOrgUrlSmall(), vc.getCatName(), 
				vc.getParentId(), v.getSummary(), v.getContent(), v.getPrice(), 
				v.getIsFree(), v.getLookFront(), vpl.getCreateTime(), vpl.getPlayTimes());
		vdList.add(dto);
	}
}

 特别注意: 这块有些问题,明明应该返回Clazz的List的,但确返回包含Clazz和Student的Object的List, 使用场合:基于对象的查询,复杂查询

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值