使用 Spring-Data JPA 中的项目列表的包含查询搜索多个列
Searching multiple colums with a Contains query with a list of Items in Spring-Data JPA
我正在图书馆工作 API,我的目标是搜索一本书。这本书现在有两个我想搜索的有趣的值:标题和简介(书背面的文字)。
底层数据库是MariaDB。
我构建了一个 JPA 查询:
Iterable<Book> findByTitleContainsOrBlurbContains(String query, String query2)
query和query2的内容相同。对于一个词的搜索,这种方法工作得很好,但一旦有两个或更多的词,当词在 blurb 和 title 之间混合时,这种方法就停止工作了。这是可以理解的。
我的第二次尝试是将每个术语拆分为一个字符串值列表。
Iterable<Book> findByTitleContainsIsInOrBlurbContainsIsIn(List<String> query, List<String> query2);
这也没有用。应用程序无法编译。
有没有办法在 contain-context 中用项目列表搜索两列?
正则表达式查询可能是实现此目的的一种方法,如下所述:
MySQL LIKE IN()?
虽然 REGEX
是列出的关键字之一,但 spring-data-jpa 似乎(还?)不支持它(2.5 版:regex-type
is there but 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'.
见here for a complete example with some tests
我正在图书馆工作 API,我的目标是搜索一本书。这本书现在有两个我想搜索的有趣的值:标题和简介(书背面的文字)。
底层数据库是MariaDB。
我构建了一个 JPA 查询:
Iterable<Book> findByTitleContainsOrBlurbContains(String query, String query2)
query和query2的内容相同。对于一个词的搜索,这种方法工作得很好,但一旦有两个或更多的词,当词在 blurb 和 title 之间混合时,这种方法就停止工作了。这是可以理解的。
我的第二次尝试是将每个术语拆分为一个字符串值列表。
Iterable<Book> findByTitleContainsIsInOrBlurbContainsIsIn(List<String> query, List<String> query2);
这也没有用。应用程序无法编译。
有没有办法在 contain-context 中用项目列表搜索两列?
正则表达式查询可能是实现此目的的一种方法,如下所述: MySQL LIKE IN()?
虽然 REGEX
是列出的关键字之一,但 spring-data-jpa 似乎(还?)不支持它(2.5 版:regex-type
is there but 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'.
见here for a complete example with some tests