zoukankan      html  css  js  c++  java
  • 关于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查询前手动执行一次主键查询。

  • 相关阅读:
    【大数据】中文词频统计
    【大数据】复合数据类型,英文词频统计
    Hadoop综合大作业
    分布式文件系统HDFS练习
    安装关系型数据库MySQL 安装大数据处理框架Hadoop
    爬取全部的校园新闻
    作业六|获取一篇新闻的全部信息
    理解爬虫原理
    作业——04 中文词频统计
    复合数据类型,英文词频统计
  • 原文地址:https://www.cnblogs.com/cielosun/p/6727254.html
Copyright © 2011-2022 走看看