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的优点。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM