gpt4 book ai didi

java - Spring-boot JPA,使用 LIKE 和 NULL 字段进行查询

转载 作者:行者123 更新时间:2023-11-30 01:57:07 24 4
gpt4 key购买 nike

我正在使用 Spring-Boot 1.5.10,JPA 连接到 SQL Server 2016。我确实有一个正在执行 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);

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

最佳答案

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

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

以太坊

关于java - Spring-boot JPA,使用 LIKE 和 NULL 字段进行查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54021063/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com