hql语句拼接模糊查询

第一种:

@Override
public List<Salary> findSomeSalary( Integer swid,String sdesk, Date stime) {
  StringBuffer hql=new StringBuffer();
  hql.append("from Salary sa where 1=1");
  if (sdesk!=null && sdesk.length()!=0) {
    hql.append(" and sa.desk.deId like '%"+sdesk+"% ");
  }else if (swid!=null ) {
    hql.append(" and sa.worker.WId  like '%"+swid+"%' ");
  }else if (stime!=null ) {
    hql.append(" and sa.saTime like '%"+stime+"%' ");
  }
  List<Salary> salaries=(List<Salary>) this.getHibernateTemplate().find(hql.toString());
  return salaries;
}

 

第二种:

@Override
public List<Apply> findByState2(String apstate) {
  String hql= "from Apply app where 1=1";
  if (apstate.length() != 0 && apstate!=null){
    hql=hql+" and app.appState like '%"+apstate+"%'";
  }
  List<Apply> applies=(List<Apply>)this.getHibernateTemplate().find(hql);
  return applies;
}

 

易错点:

1、使用模糊查询拼接HQL语句是用 like 而不是 “ = ”

2、属性应该与实体类定义的一致,而不是数据库里面的。

3、活用hibernate的优点。

转载于:https://www.cnblogs.com/annuush/p/10967083.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值