首页 > 解决方案 > Spring-boot JPA,使用 LIKE 和 NULL 字段查询

问题描述

我正在使用 Spring-Boot 1.5.10 和连接到 SQL Server 2016 的 JPA。我确实有一个正在执行 LIKE 的自定义查询,但是当字段为 NULL 时,不返回任何记录:

@Query("SELECT s FROM Speaker s where " +
        "(" +
        "lower(s.lastName) like lower(concat('%', ?1,'%')) " +
        "OR lower(s.firstName) like lower(concat('%', ?1,'%')) " +
        "OR lower(s.biography) like lower(concat('%', ?1,'%'))" +
        ") " +
        "and lower(s.language) like lower(concat('%', ?2,'%')) " +
        "and lower(s.contactType) like lower(concat('%', ?3,'%')) " +
        "and s.fee <= ?4")
Page<Speaker> findByContains(String criteria, String language, String type, int fee, Pageable pageable);

Query 连接到一个 REST 控制器,其中传递了 1 个参数criteria,问题是您可能会调用 REST 控制器而根本没有传递任何条件。在这种情况下,查询不会返回其中一个搜索条件在数据库中为 NULL 的记录。

标签: javasql-serverspringspring-boot

解决方案


您可以使用 COALESCE 将 null 转换为 emtpy 字符串:

lower(COALESCE(s.firstName,''))

等等


推荐阅读