java - 为什么我的 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
解决方案
完成,jpa 存储库上的 Like 子句有点像 dodoo ,所以我不得不这样写:
LIKE CONCAT(CONCAT('%', :main), '%')
(sintax 只对 oracle 数据库是正确的,所以要小心,因为 mySql 和其他人这样写:
LIKE CONCAT('%', :param, '%')
谢谢@Arnaud
推荐阅读
- android - 推送通知未在 kitkat 4.4.2 版本中显示
- c++ - 当我将 unique_ptr 或 shared_ptr 传递给引用指向对象的第三方函数时崩溃
- angular - 替代 ngx-datatable-group-footer
- ios - 使用 WebRTC 通过 ReplayKit 发送 iOS 设备的屏幕截图
- python - pyBarcode - imageWriter 设置
- php - PHP 版本不等于 OSX 上的 Homebrew
- javascript - 工具提示中图表的缩写值
- blueprism - 将自定义 VBO 对象存储在蓝色棱镜中的位置
- jsf - 如何以编程方式在 af:inputFile 中设置文件名和内容
- c# - Equals 和 GetHashCode 都不会在 IEqualityComparer 上被调用