首页 > 解决方案 > 为什么我的 JpaRepository (spring-data-jpa) 自定义查询返回一个空列表?

问题描述

我正在尝试开发一个网络应用程序,用户可以在其中发布他们的广告,我目前正在研究一个广告部分,它只是一个发送搜索模型的表单(它有一个字符串,它是写在搜索栏上的文本和一些不需要的过滤器)到后端(spring boot),后端获取字符串并将其提供给 JpaRepository 方法,该方法应该对我的 oracle 数据库进行查询并将结果集作为 AdEntity 列表返回给我,唯一的问题是列表总是空的,这是方法:

@Query(value = "select distinct a.ann_id, a.nome, a.autore, a.descrizione, a.prodotto, a.prezzo "
        + "from annunci a, prodotti p "
        + "where a.prodotto = p.prod_id  "
        + "and (a.nome like '%:main%' or p.nome like '%:main%')", nativeQuery = true)
public List<AnnuncioEntity> searchWithoutFilters(String main);

这就是我所说的:

@PostMapping("/")
public List<FullAnnuncio> searchAnnunci(@RequestBody SearchEntity search) {
    List<AnnuncioEntity> li = annuncioDAO.searchWithoutFilters(search.getMain());
    return null;
}

li 列表始终为空(使用调试器检查),我不知道如何修复它,我确信查询有效并产生预期的结果集,因为我首先在 sqlDeveloper 上尝试了它,并且没有我从搜索中获得的字符串'不为空

请帮助我对这些东西很陌生,因为我什至不是初级程序员 lmao

标签: javasqlspringspring-bootspring-data-jpa

解决方案


完成,jpa 存储库上的 Like 子句有点像 dodoo ,所以我不得不这样写:

LIKE CONCAT(CONCAT('%', :main), '%')

(sintax 只对 oracle 数据库是正确的,所以要小心,因为 mySql 和其他人这样写:

LIKE CONCAT('%', :param, '%')

谢谢@Arnaud


推荐阅读