第一種:
@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的優點。