首页 > 解决方案 > Spring Boot JPA Repository IS NULL,LIKE 不工作

问题描述

我按姓名、姓氏和号码过滤。有时我想按单个名称搜索,有时按姓名和姓氏搜索,有时按 all.LIKE 和 is null 操作不起作用。

例子

姓名:亚当姓氏:最大编号:1235464 工作

姓名:亚当姓氏:最大编号:(空)不工作

        2021-09-13 15:45:48 ERROR o.a.c.c.C.[.[.[.[dispatcherServlet] - Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.dao.InvalidDataAccessResourceUsageException: could not extract ResultSet; SQL [n/a]; nested exception is org.hibernate.exception.SQLGrammarException: could not extract ResultSet] with root cause
oracle.jdbc.OracleDatabaseException: ORA-01722: invalid number

@Transactional
    @Modifying
    @Query(value = "SELECT U.* FROM USER U  "
            + "LEFT JOIN CV ON U.USERID=CV.USERID  "
            + "JOIN PROFIL P ON P.CV_ID=CV.CV_ID  "
            + "AND(:name is null OR P.name LIKE %:name% ) "
            + "AND (:surname is null OR P.surname LIKE %:surname% ) "
            + "AND (:no is null OR U.no=:no ) ", nativeQuery = true)
    public List<User> findByDynamicQuery(@Param("name") String name, @Param("surname") String surname, @Param("no") String no);

标签: sqlspring-bootjpa

解决方案


我需要您的用户模型类的代码来验证这一点,但这oracle.jdbc.OracleDatabaseException: ORA-01722: invalid number通常意味着将字符串转换为数字时出现问题。因为只有当您的号码是时它才起作用,NULL所以我怀疑您使用的是原始类型(例如int, long)而不是实际的 Number 类。如果是这种情况,则将模型中的/替换为int/ 。longIntegerLong

如果不是这样,请分享更多数据,我们会尽力提供帮助。


推荐阅读