此前我们已经介绍了HibernateTemplate的使用配置方法,但是对其使用没有仔细说明。因为最近比较忙,我先不去介绍,而是重点说明一下容易引起问题的findByExample方法。
我尝试反编译HibernateTemplate去直接找到findByExample()方法的实现,但是发现其基于多个其他API,最主要是Hibernate提供的Criteria类,因此我只打算简单说明一下findByExample这个方法的适用范围。
- findByExample()会忽略所有值为null的参数,但如果参数包含8种基础类型,它们的默认空值不是null,这样就会导致错误。所以,请不要将带有基础类型变量的bean用于findByExample。
- findByExample()不支持主键。
当我们想要通过主键查询一个值时,应当适用HibernateTemplate提供的Object get(String entityClassName, Serializable id)方法,前者是所查的表的实例的类名(注意不是真实的表名),后者为主键。
如果我们一定要在findByExample()方法中结合主键的查询(就是对已经写好的出了问题的代码背锅......)可以这样:
public List findByExample(UserEntity userEntity) {
if (userEntity.getAccountNumber() != null)
return hibernateTemplate.find("from UserEntity userEntity where userEntity.accountNumber=" + userEntity.getAccountNumber());
return hibernateTemplate.findByExample(userEntity);
}
在用example查询前手动执行一次主键查询。