通过SQL查询多个表的结果且分页

本文介绍如何在hibernate3.2及以上版本中通过SQL查询数据,并提供两种方式将查询结果转换为对象或map集合。重点讨论了参数设置、结果限制以及查询性能优化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如下方式:需要使用hibernate3.2及以上版本:

 

@SuppressWarnings("unchecked")
	public List queryObjectsBySQL(final String HQLStr,
			final Object[] parmaters, final Integer startRow,
			final Integer rowCount) throws DaoException {

		try {
			List list = getHibernateTemplate().executeFind(
					new HibernateCallback() {
						public Object doInHibernate(Session session)
								throws HibernateException, SQLException {
							
							Query query = session.createSQLQuery(HQLStr).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);

							if (startRow != null && startRow.intValue() >= 0
									&& rowCount != null
									&& rowCount.intValue() >= 0) {
								query.setFirstResult(startRow);
								query.setMaxResults(rowCount);
							}
							if (parmaters != null && parmaters.length > 0) {
								for (int i = 0; i < parmaters.length; i++) {
									if((parmaters[i]) instanceof List){
										List tempList = (List) parmaters[i];
										query.setParameterList("typeids", tempList);
									}else{

										query.setParameter(i, parmaters[i]);
									}
								}
							}
							List list = query.list();
							return list;
						}

					});
			return list;
		} catch (Exception e) {
			throw new DaoException(DaoExceptionType.TYPE_CODE_DAO, e);
		}

	}

注意:

     Query query = session.createSQLQuery(HQLStr);  List list= query.list();  返回的是object的数组,内容只包含值,不包含名称,

   Query query = session.createSQLQuery(HQLStr).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); List list = query.list();  返回的是map类型的集合,包含键值对,既有名称又有值。

 

搜藏:http://www.blogjava.net/rain1102/archive/2009/02/23/256344.html   把查询结果转为对象或者map

          http://langgufu.iteye.com/blog/1565397

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值