Hibernate的参数类型(集合和数组)

本文详细介绍了如何在HQL查询中使用集合与数组作为参数的方法。对于集合参数,通过setParameterList方法可以实现对HQL中IN子句的有效利用;而对于多个参数的情况,则可以通过构造Object数组并传递给find方法来实现。这两种方式都是在Java环境下操作HQL时常见的实践。

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

(1)关于以集合为参数的使用
注意“setParameterList("organizations", organizations)” organizations为一个集合

java 代码
  1. Collection organizations;   
  2.                    
  3. String queryString = "select distinct (e) from RetiredEmployee as e "  
  4. "where e.masterPost.organization in (:organizations) " + sortInfo.toString();   
  5. Query query = session.createQuery(queryString).setParameterList("organizations", organizations);  

 

(2)关于以数组为参数的使用
本HQL语句中有4个参数
所以构造长度为4 的Object[] params 的对象参数

java 代码
  1. public Collection findEmployeesForRetirement(int maleAge, int femaleAge,   
  2.             int beforeMonth)   
  3.     {   
  4. String queryString = "select distinct e from Employee e where "
     + "(e.sex = ? and e.birthday < ?) or (e.sex = ? and e.birthday < ?)";
  5.   Object[] params = new Object[] {
        new Integer(Employee.SEX_MALE),
        maleBirthDay.getTime(),
        new Integer(Employee.SEX_FEMALE),
        femaleBirthDay.getTime() };
      return getHibernateTemplate().find(queryString, params);
  6.     }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值