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