hibernate hql return object or list 指定类型

java.lang.ClassCastException: [Ljava.lang.Object; incompatible with com.shkco.adsr3.cbm.vo.ICustomerAccount

 

看到这错误都知道是数据类型转换不匹配,Object 与ICustomerAccount.

 

DAO 方法原始如下:

	public List<ICustomerAccount> getListOfCustomerAccount(ISessionContext sessionContext, IClientCentricCustomer clientCentricCustomer) {
		
		ISessionWrapper session = getCurrentSession();
		
		String sqlStr = "from " + CustomerAccount.class.getName() 
				+ " as cust join cust.companyGroup as cg where cg.compGrpId = "
				+ ":companyGroupId "
				+ " and cust.ccdRef= :ccdRef ";		
		
		Query query = session.createQuery(sqlStr);

		query.setParameter("companyGroupId", getCompGrpId(sessionContext));
		query.setParameter("ccdRef", clientCentricCustomer);
		
		
		return query.list();
	}

 

没有注意看代码,因为是直接写的from .....没有写select 对象,所以返回的就是Object.

修改如下即可:

加上Select cust,即ICustomerAccount 对象就ok啦。

	public List<ICustomerAccount> getListOfCustomerAccount(ISessionContext sessionContext, IClientCentricCustomer clientCentricCustomer) {
		
		ISessionWrapper session = getCurrentSession();
		
		String sqlStr = "select cust  from " + CustomerAccount.class.getName() 
				+ " as cust join cust.companyGroup as cg where cg.compGrpId = "
				+ ":companyGroupId "
				+ " and cust.ccdRef= :ccdRef ";		
		
		Query query = session.createQuery(sqlStr);

		query.setParameter("companyGroupId", getCompGrpId(sessionContext));
		query.setParameter("ccdRef", clientCentricCustomer);
		
		
		return query.list();
	}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值