关于Spring的HibernateTemplate的findByExample方法使用时的一点注意。

此前我们已经介绍了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查询前手动执行一次主键查询。

posted @ 2017-04-18 13:09  CieloSun  阅读(5752)  评论(0编辑  收藏  举报