Searching multiple colums with a Contains query with a list of Items in Spring-Data JPA(使用Spring-data JPA中的项目列表使用CONTAINS查询搜索多列)
问题描述
我正在开发一个图书馆API,我的目标是搜索一本书。目前,这本书有两个我要搜索的有趣的值:标题和格式回复信息(书背面的文本)。
基础数据库为MariaDB。
我构造了一个JPA查询:
Iterable<Book> findByTitleContainsOrBlurbContains(String query, String query2)
query和query2的内容相同。对于一个词的搜索,这种方法工作得很好,但是一旦有两个或更多的词,当这些词混合在简介和标题中时,这种方法就不起作用了。这是可以理解的。
我的第二次尝试是将每个术语拆分到字符串值列表中。
Iterable<Book> findByTitleContainsIsInOrBlurbContainsIsIn(List<String> query, List<String> query2);
这个也不管用。应用程序未编译。
有没有办法在CONTAIN-CONTEXT中搜索包含项目列表的两列?
推荐答案
正则表达式查询可以实现此目的,如下所述: MySQL LIKE IN()?
虽然REGEX
是列出的关键字之一,但Spring-data-jpa不是(还没有?)似乎支持它(版本2.5:regex-type
is there但是not evaluated,所以像queryByAttributeRegex(String regex)
这样的东西不起作用)。
备用本机查询:
@Query(nativeQuery = true, value = "SELECT * FROM my_entity WHERE "
+ "attribute1 REGEXP CONCAT_WS('|', :list1) " + "OR "
+ "attribute2 REGEXP CONCAT_WS('|', :list2) ")
List<MyEntity> findByAttributeList1Or2( // (method name does not matter)
@Param("list1") Collection<String> list1,
@Param("list2") Collection<String> list2);
CONCAT_WS
加入提供的列表,例如('val1', 'val2')
到'val1|val2'
,该列表将匹配,例如‘Completeval2
xxx’。
有关some tests的完整示例,请参阅here
这篇关于使用Spring-data JPA中的项目列表使用CONTAINS查询搜索多列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用Spring-data JPA中的项目列表使用CONTAINS查询搜索多列
基础教程推荐
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01