annuush

第一种:

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

分类:

技术点:

相关文章: