多条件查询Hql

1.今天学习的是Hibernate中Hql的多条件查询问题。我们在真正的网站开发过程中,难免会遇到多条件查询的问题。当查询条件大于或者3个时,我们必须要做好多条件查询。

(1)在多条件查询中,当查询条件大于或者等于3时,我们就需要把查询条件封装成一个dto类,在这个类中,只需要写好几个查询条件生成get()和set()方法就行了。

(2)当在页面进行查询时,我们让页面跳转到servlet进行后台处理,在servlet中,我们读取查询条件进行判断组装成dto对象,然后在实现类中取判断完成多条件查询。主要代码如下:

        String hql="from Emp where 1=1 ";
        if(dto.getName()!=null&&!"".equals(dto.getName())){
            hql=hql+" and name like :name";
        }
        if(dto.getStartDate()!=null){
            hql=hql+" and hireDate>:startDate";
        }
        if(dto.getEndDate()!=null){
            hql=hql+" and hireDate<:endDate";
        }
        Query query=HibernateUtil.getSession().createQuery(hql);
        List<Emp> list=query.setProperties(dto).list();
        HibernateUtil.closeSession();
        return list;

在这里我要说的是在hql语句中,where后面写了个1=1,写1=1的原因就是,由于是多条件查询,我们也不知道用户到底输入了几个条件,导致我们hql后续语句中的and不知道什么时间加进去,所以我们在这里写了一个等式,这样就可以完美解决这个问题。多条件查询的精华也就在这个等式上了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值