关于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查询前手动执行一次主键查询。

转载于:https://www.cnblogs.com/cielosun/p/6727254.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值